4
0

kfserver 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729
  1. #!/bin/bash
  2. # Killing Floor
  3. # Server Management Script
  4. # Author: Daniel Gibbs
  5. # Website: http://danielgibbs.co.uk
  6. # Version: 101113
  7. #### Variables ####
  8. # Notification Email
  9. # (on|off)
  10. emailnotification="off"
  11. email="email@example.com"
  12. # Steam login
  13. steamuser="username"
  14. steampass="password"
  15. # Steam
  16. appid="215360"
  17. # Directorys
  18. rootdir="$(cd "$(dirname "${BASH_SOURCE[0]}" )" && pwd )"
  19. selfname="$0"
  20. filesdir="${rootdir}/serverfiles"
  21. systemdir="${filesdir}/System"
  22. backupdir="${rootdir}/backups"
  23. compressedmapsdir="${rootdir}/Maps-Compressed"
  24. # Server Details
  25. servicename="kf-server"
  26. gamename="Killing Floor"
  27. engine="unreal2"
  28. ini="${servicename}.ini"
  29. servername=$(grep -s ServerName= ${systemdir}/${ini} | sed 's/ServerName=//g')
  30. # Logging
  31. logdays="7"
  32. scriptlogdir="${rootdir}/log/script"
  33. consolelogdir="${rootdir}/log/console"
  34. scriptlog="${scriptlogdir}/${servicename}-script.log"
  35. consolelog="${consolelogdir}/${servicename}-console.log"
  36. emaillog="${scriptlogdir}/${servicename}-email.log"
  37. scriptlogdate="${scriptlogdir}/${servicename}-script-$(date '+%d-%m-%Y-%H-%M-%S').log"
  38. consolelogdate="${consolelogdir}/${servicename}-console-$(date '+%d-%m-%Y-%H-%M-%S').log"
  39. # Start Variables
  40. defaultmap="KF-BioticsLab.rom"
  41. parms="server ${defaultmap}?game=KFmod.KFGameType?VACSecured=true -nohomedir ini=${ini} log=${logfile}"
  42. ##### Script #####
  43. # Do not edit
  44. # unless you know
  45. # what you are doing
  46. fn_rootcheck(){
  47. if [ `whoami` = "root" ];then
  48. echo -e "[\e[0;31m FAIL \e[0;39m] Script will not run as root!"
  49. exit
  50. fi
  51. }
  52. fn_syscheck(){
  53. if [ ! -e ${systemdir} ];then
  54. echo -e "[\e[0;31m FAIL \e[0;39m] Cannot access ${systemdir}: No such directory"
  55. exit
  56. fi
  57. }
  58. fn_runcheck(){
  59. tmuxwc=$(tmux list-sessions 2>&1|awk '{print $1}'|grep -v failed|grep ${servicename}|wc -l)
  60. if [ ${tmuxwc} -eq 1 ];then
  61. fn_serverquery
  62. echo -en "\r[\e[0;36m INFO \e[0;39m] ${servicename}: ${servername} is already running"
  63. echo -e "$(date '+%b %d %H:%M:%S') ${servicename}: ${servername} is already running" >> ${scriptlog}
  64. sleep 0.5
  65. echo -en "\n"
  66. exit
  67. fi
  68. }
  69. fn_compressmaps(){
  70. fn_rootcheck
  71. clear
  72. echo "${gamename} Map Compressor"
  73. echo "============================"
  74. echo "Will compress all maps in:"
  75. echo ""
  76. pwd
  77. echo ""
  78. echo "Compressed maps saved to:"
  79. echo ""
  80. echo "${compressedmapsdir}"
  81. echo ""
  82. while true; do
  83. read -p "Start compression [y/N]" yn
  84. case $yn in
  85. [Yy]* ) break;;
  86. [Nn]* ) echo Exiting; return 1 ;;
  87. * ) echo "Please answer yes or no.";;
  88. esac
  89. done
  90. mkdir ${compressedmapsdir} > /dev/null 2>&1
  91. rm -rfv ${filesdir}/Maps/*.uz2
  92. cd ${systemdir}
  93. for map in `ls ${filesdir}/Maps`; do
  94. if [ `getconf LONG_BIT` = "64" ]
  95. then
  96. ./ucc-bin-linux-amd64 compress ../Maps/${map} --nohomedir
  97. else
  98. ./ucc-bin compress ../Maps/${map} --nohomedir
  99. fi
  100. done
  101. mv -fv ${filesdir}/Maps/*.uz2 ${compressedmapsdir}
  102. }
  103. fn_steamguard(){
  104. fn_rootcheck
  105. fn_syscheck
  106. clear
  107. fn_header
  108. fn_steamdl
  109. clear
  110. fn_header
  111. echo "If you are gettng an error:"
  112. echo ""
  113. echo "Login Failure: Account Logon Denied Failed."
  114. echo ""
  115. echo "You should now get an email from Steam with a Steam Guard code"
  116. echo ""
  117. read -p "Press [Enter] key to when you have the code..."
  118. clear
  119. fn_header
  120. echo "Please enter Steam Guard Code"
  121. echo "=============================="
  122. echo -n "Code: "
  123. read CODE
  124. touch guard.txt
  125. chmod 0600 guard.txt
  126. echo "set_steam_guard_code $CODE" > guard.txt
  127. echo "login ${steamuser} ${steampass}" >> guard.txt
  128. echo "quit" >> guard.txt
  129. STEAMEXE=steamcmd ./steam.sh +runscript guard.txt
  130. rm guard.txt
  131. cd ../
  132. echo "=============================="
  133. echo "Complete!"
  134. cd ${rootdir}
  135. }
  136. fn_logmanager(){
  137. if [ ! -e ${consolelog} ];then
  138. touch ${consolelog}
  139. fi
  140. # log manager will active if finds logs older than ${logdays}
  141. if [ `find ${scriptlogdir}/* -mtime +${logdays} |wc -l` -ne "0" ];then
  142. echo -e "[\e[0;32m OK \e[0;39m] Starting log cleaner"
  143. echo -e "$(date '+%b %d %H:%M:%S') ${servicename}: Starting log cleaner" >> ${scriptlog}
  144. echo -e "[\e[0;36m INFO \e[0;39m] Removing logs older than ${logdays} days"
  145. echo -e "$(date '+%b %d %H:%M:%S') ${servicename}: Removing logs older than ${logdays} days" >> ${scriptlog}
  146. find ${scriptlogdir}/* -mtime +${logdays} |tee >> ${scriptlog}
  147. find ${consolelogdir}/* -mtime +${logdays} |tee >> ${scriptlog}
  148. scriptcount=$(find ${scriptlogdir}/* -mtime +${logdays}|wc -l)
  149. consolecount=$(find ${consolelogdir}/* -mtime +${logdays}|wc -l)
  150. count=$((${scriptcount} + ${consolecount}))
  151. find ${scriptlogdir}/* -mtime +${logdays} -exec rm {} \;
  152. find ${consolelogdir}/* -mtime +${logdays} -exec rm {} \;
  153. echo -e "[\e[0;36m INFO \e[0;39m] Log cleaner removed ${count} log files"
  154. echo -e "$(date '+%b %d %H:%M:%S') ${servicename}: Log cleaner removed ${count} log files" >> ${scriptlog}
  155. fi
  156. }
  157. fn_debugserver(){
  158. fn_rootcheck
  159. fn_syscheck
  160. echo ""
  161. echo "${gamename} Debug"
  162. echo "============================"
  163. echo ""
  164. echo -e "Use for identifying server issues only!"
  165. echo -e "Press CTRL+c to drop out of debug mode"
  166. echo -e "\e[0;31mWARNING!\e[0;39m If ${servicename} is already running it will be stopped"
  167. echo ""
  168. while true; do
  169. read -p "Continue? [y/N]" yn
  170. case $yn in
  171. [Yy]* ) break;;
  172. [Nn]* ) echo Exiting; return 1 ;;
  173. * ) echo "Please answer yes or no.";;
  174. esac
  175. done
  176. fn_stopserver
  177. echo -en "[ .... ] Starting ${servicename}: ${servername} debug mode"
  178. echo -e "$(date '+%b %d %H:%M:%S') ${servicename}: Starting ${servername} debug mode" >> ${scriptlog}
  179. sleep 0.5
  180. echo -en "\r[\e[0;32m OK \e[0;39m] Starting ${servicename}: ${servername}"
  181. echo -e "$(date '+%b %d %H:%M:%S') ${servicename}: Started ${servername} debug mode" >> ${scriptlog}
  182. sleep 0.5
  183. echo -en "\n"
  184. cd ${systemdir}
  185. ./ucc-bin ${parms}
  186. }
  187. fn_console(){
  188. fn_rootcheck
  189. fn_syscheck
  190. echo ""
  191. echo "${gamename} Console"
  192. echo "============================"
  193. echo ""
  194. echo "Press \"CTRL+b d\" to exit console"
  195. echo -e "\e[0;31mWARNING!\e[0;39m Do NOT press CTRL+c to exit"
  196. echo ""
  197. while true; do
  198. read -p "Continue? [y/N]" yn
  199. case $yn in
  200. [Yy]* ) break;;
  201. [Nn]* ) echo Exiting; return 1 ;;
  202. [Nn]* ) echo Exiting; return 1 ;;
  203. * ) echo "Please answer yes or no.";;
  204. esac
  205. done
  206. echo -en "\r[ .... ] Starting ${servicename} console"
  207. sleep 0.5
  208. tmuxwc=$(tmux list-sessions 2>&1|awk '{print $1}'|grep -v failed|grep ${servicename}|wc -l)
  209. if [ ${tmuxwc} -eq 1 ];then
  210. echo -e "\r[\e[0;32m OK \e[0;39m] Starting ${servicename} console"
  211. echo -e "$(date '+%b %d %H:%M:%S') ${servicename}: ${servername} console accessed" >> ${scriptlog}
  212. sleep 1
  213. tmux attach-session -t ${servicename}
  214. else
  215. echo -e "\r[\e[0;31m FAIL \e[0;39m] Starting ${servicename} console: ${servername} not running"
  216. sleep 0.5
  217. while true; do
  218. read -p "Do you want to start the server? [y/N]" yn
  219. case $yn in
  220. [Yy]* ) fn_startserver;break;;
  221. [Nn]* ) break;;
  222. * ) echo "Please answer yes or no.";;
  223. esac
  224. done
  225. fi
  226. }
  227. fn_backupserver(){
  228. fn_rootcheck
  229. fn_syscheck
  230. backupname="${servicename}-$(date '+%Y-%m-%d-%H%M%S')"
  231. echo ""
  232. echo "${gamename} Backup"
  233. echo "============================"
  234. echo ""
  235. echo "The following backup will be created."
  236. echo ""
  237. echo "${backupdir}/${backupname}.tar.gz"
  238. echo ""
  239. while true; do
  240. read -p "Continue? [y/N]" yn
  241. case $yn in
  242. [Yy]* ) break;;
  243. [Nn]* ) echo Exiting; return 1 ;;
  244. * ) echo "Please answer yes or no.";;
  245. esac
  246. done
  247. tmuxwc=$(tmux list-sessions 2>&1|awk '{print $1}'|grep -v failed|grep ${servicename}|wc -l)
  248. if [ ${tmuxwc} -eq 1 ];then
  249. echo -e "\e[0;31mWARNING!\e[0;39m ${servicename} is currently running"
  250. while true; do
  251. read -p "Would you like to stop ${servicename} while running the backup? [y/N]" yn
  252. case $yn in
  253. [Yy]* ) fn_stopserver;break;;
  254. [Nn]* ) break;;
  255. * ) echo "Please answer yes or no.";;
  256. esac
  257. done
  258. fi
  259. echo -en "[ .... ] Starting ${servicename}: ${servername} backup"
  260. echo -e "$(date '+%b %d %H:%M:%S') ${servicename}: Starting ${servername} backup" >> ${scriptlog}
  261. sleep 0.5
  262. echo -en "\r[\e[0;32m OK \e[0;39m] Starting ${servicename}: ${servername} backup"
  263. echo -e "$(date '+%b %d %H:%M:%S') ${servicename}: Started ${servername} backup" >> ${scriptlog}
  264. sleep 1
  265. echo -en "\n"
  266. cd ${rootdir}
  267. mkdir ${backupdir} > /dev/null 2>&1
  268. tar -cvzf ${backupdir}/${backupname}.tar.gz --exclude ${backupdir} ${rootdir}
  269. echo -en "\r${servicename} backup complete"
  270. echo -e "$(date '+%b %d %H:%M:%S') ${servicename}: backup complete" >> ${scriptlog}
  271. }
  272. fn_details(){
  273. echo ""
  274. echo "${gamename} Server Details"
  275. echo "============================"
  276. echo ""
  277. echo "${servername} Ports"
  278. echo "======================="
  279. gameport=$(grep Port= ${systemdir}/${ini}|grep -v Master|grep -v LAN|grep -v Proxy|grep -v Listen|sed 's/\Port=//g')
  280. queryport=$((${gameport} + 1))
  281. gsqueryport=$(grep OldQueryPortNumber= ${systemdir}/${ini}|sed 's/\OldQueryPortNumber=//g')
  282. udplinkport=$((${gameport} + 2))
  283. webadminport=$(grep ListenPort= ${systemdir}/${ini}|sed 's/\ListenPort=//g')
  284. if [ "${engine}" == "unreal" ];then
  285. webadminuser=$(grep AdminUsername= ${systemdir}/${ini}|sed 's/\AdminUsername=//g')
  286. else
  287. webadminuser=$(grep AdminName= ${systemdir}/${ini}|sed 's/\AdminName=//g')
  288. fi
  289. webadminpass=$(grep AdminPassword= ${systemdir}/${ini}|sed 's/\AdminPassword=//g')
  290. echo "Ports the server is currently using"
  291. echo ""
  292. echo "DIRECTION DESCRIPTION PORT INI VARIABLE"
  293. echo "INBOUND Game Port ${gameport} UDP Port=${gameport}"
  294. echo "INBOUND Query Port ${queryport} UDP n/a"
  295. if [ "${engine}" == "unreal" ];then
  296. echo "OUTBOUND UdpLink Port (random) ${udplinkport}+ UDP n/a"
  297. fi
  298. if [ "${engine}" != "unreal" ] && [ "${appid}" != "223250" ];then
  299. echo "INBOUND GameSpy Query Port ${gsqueryport} UDP OldQueryPortNumber=${gsqueryport}"
  300. fi
  301. if [ "${appid}" == "215360" ];then
  302. echo "OUTBOUND Master Server port 28852 TCP/UDP n/a"
  303. else
  304. echo "OUTBOUND Master Server port 28900/28902 TCP/UDP n/a"
  305. fi
  306. if [ "${appid}" ];then
  307. if [ "${appid}" == "223250" ];then
  308. echo "OUTBOUND Steam Port 20610 UDP n/a"
  309. else
  310. echo "OUTBOUND Steam Port 20660 UDP n/a"
  311. fi
  312. fi
  313. echo "INBOUND WebAdmin ${webadminport} TCP ListenPort=${webadminport}"
  314. echo ""
  315. echo "${servername} WebAdmin"
  316. echo "======================="
  317. echo "WebAdmin URL: http://localhost:${webadminport}"
  318. echo "WebAdmin Username: ${webadminuser}"
  319. echo "WebAdmin Password: ${webadminpass}"
  320. echo ""
  321. echo "Config file"
  322. echo "${systemdir}/${ini}"
  323. echo ""
  324. }
  325. fn_distro(){
  326. arch=$(uname -m)
  327. kernel=$(uname -r)
  328. if [ -f /etc/lsb-release ]; then
  329. os=$(lsb_release -s -d)
  330. elif [ -f /etc/debian_version ]; then
  331. os="Debian $(cat /etc/debian_version)"
  332. elif [ -f /etc/redhat-release ]; then
  333. os=$(cat /etc/redhat-release)
  334. else
  335. os="$(uname -s) $(uname -r)"
  336. fi
  337. }
  338. fn_uptime(){
  339. uptime=$(</proc/uptime)
  340. uptime=${uptime%%.*}
  341. minutes=$(( uptime/60%60 ))
  342. hours=$(( uptime/60/60%24 ))
  343. days=$(( uptime/60/60/24 ))
  344. }
  345. fn_load(){
  346. load=$(uptime | awk -F 'load average' '{ print $2 }')
  347. }
  348. fn_emailnotification(){
  349. fn_distro
  350. fn_uptime
  351. fn_load
  352. {
  353. echo -e "========================================\n${servicename} details\n========================================\n"
  354. echo -e "Service: ${servicename}"
  355. echo -e "Game: ${gamename}"
  356. echo -e "Server: ${servername}"
  357. echo -e "Failure reason: ${failurereason}"
  358. echo -e "Action Taken: ${actiontaken}\n"
  359. echo -e "========================================\nServer details\n========================================\n"
  360. echo -e "Date: $(date)"
  361. echo -e "Distro: ${os}"
  362. echo -e "Arch: ${arch}"
  363. echo -e "Kernel: ${kernel}"
  364. echo -e "Hostname: $HOSTNAME"
  365. echo -e "Uptime: ${days}d, ${hours}h, ${minutes}m"
  366. echo -e "Avg Load${load}\n"
  367. echo -e "========================================\nLogs\n========================================\n"
  368. echo -e "Script log\n===================\n"
  369. }|tee ${scriptlogdir}/${servicename}-email.log > /dev/null 2>&1
  370. tail -25 ${scriptlog} >> ${emaillog}
  371. if [ ! -z ${consolelog} ];then
  372. echo -e "\n\nConsole log\n====================\n" >> ${emaillog}
  373. tail -25 ${consolelog} >> ${emaillog}
  374. fi
  375. if [ ! -z ${gamelogdir} ];then
  376. echo -e "\n\nServer log\n====================\n" >> ${emaillog}
  377. tail ${gamelogdir}/*|grep -v "==>"|sed '/^$/d'|tail -25 >> ${emaillog}
  378. fi
  379. mail -s "${subject}" ${email} < ${emaillog}
  380. echo -en "[\e[0;36m INFO \e[0;39m] Sent email notification to ${email}"
  381. echo -e "$(date '+%b %d %H:%M:%S') ${servicename}: Sent email notification to ${email}" >> ${scriptlog}
  382. }
  383. fn_emailtest(){
  384. fn_rootcheck
  385. fn_syscheck
  386. echo -e "$(date '+%b %d %H:%M:%S') ${servicename}: Emailing test notification" >> ${scriptlog}
  387. if [ "${emailnotification}" = "on" ];then
  388. subject="${servicename} Email Test Notification - Testing ${servername}"
  389. failurereason="Testing ${servicename} email notification"
  390. actiontaken="Sent test email...hello is this thing on?"
  391. fn_emailnotification
  392. else
  393. echo -e "[\e[0;31m FAIL \e[0;39m] Email notification not enabled"
  394. echo -e "$(date '+%b %d %H:%M:%S') ${servicename}: Email notification not enabled" >> ${scriptlog}
  395. fi
  396. sleep 0.5
  397. echo -en "\n"
  398. }
  399. fn_serverquery(){
  400. # uses serverquery.py to directly query the server
  401. # detects if the server locks up
  402. if [ -f serverquery.py ];then
  403. echo -e "[\e[0;36m INFO \e[0;39m] serverquery.py detected"
  404. echo -e "$(date '+%b %d %H:%M:%S') ${servicename}: serverquery.py detected" >> ${scriptlog}
  405. echo -e "[\e[0;32m OK \e[0;39m] Querying ${servicename}: ${servername}: QUERYING"
  406. echo -e "$(date '+%b %d %H:%M:%S') ${servicename}: Querying ${servername}: QUERYING" >> ${scriptlog}
  407. serverquery=$(./serverquery.py 127.0.0.1 ${port} 2>&1)
  408. sleep 1
  409. if [ "${serverquery}" = "ERROR 1" ]||[ "${serverquery}" = "ERROR 2" ]||[ "${serverquery}" = "ERROR 3" ];then
  410. echo -e "[\e[0;31m FAIL \e[0;39m] Querying ${servicename}: ${servername}: ${serverquery}"
  411. echo -e "$(date '+%b %d %H:%M:%S') ${servicename}: Querying ${servername}: ${serverquery}" >> ${scriptlog}
  412. sleep 1
  413. echo -e "[\e[1;33m WARN \e[0;39m] ${servicename}: Monitor detected ${servername} has locked up!"
  414. echo -e "$(date '+%b %d %H:%M:%S') ${servicename}: Monitor detected ${servername} has locked up!" >> ${scriptlog}
  415. sleep 1
  416. fn_restartserver
  417. else
  418. echo -e "[\e[0;32m OK \e[0;39m] Querying ${servicename}: ${servername}: ${serverquery}"
  419. echo -e "$(date '+%b %d %H:%M:%S') ${servicename}: Querying ${servername}: ${serverquery}" >> ${scriptlog}
  420. sleep 1
  421. fi
  422. fi
  423. }
  424. fn_monitorserver(){
  425. fn_rootcheck
  426. fn_syscheck
  427. fn_logmanager
  428. echo -en "[ .... ] Monitor is checking ${servicename}: ${servername}"
  429. echo -e "$(date '+%b %d %H:%M:%S') ${servicename}: Monitor is checking ${servername}" >> ${scriptlog}
  430. sleep 0.5
  431. updatecheck=$(ps -ef|grep "${selfname} update"|grep -v grep|wc -l)
  432. if [ "${updatecheck}" = "0" ];then
  433. fn_runcheck
  434. echo -en "\r[\e[1;33m WARN \e[0;39m] ${servicename}: Monitor detected ${servername} had stopped!"
  435. echo -e "$(date '+%b %d %H:%M:%S') ${servicename}: Monitor detected ${servername} had stopped!" >> ${scriptlog}
  436. if [ "${emailnotification}" = "on" ];then
  437. subject="${servicename} Monitor - Starting ${servername}"
  438. failurereason="${servicename} process was not running"
  439. actiontaken="restarted ${servicename}"
  440. sleep 0.5
  441. echo -en "\n"
  442. fn_emailnotification
  443. fi
  444. sleep 0.5
  445. echo -en "\n"
  446. echo -e "$(date '+%b %d %H:%M:%S') ${servicename}: Monitor is starting ${servername}" >> ${scriptlog}
  447. fn_startserver
  448. else
  449. echo -e "[\e[0;36m INFO \e[0;39m] ${servicename}: Monitor detected ${servername} is currently checking for updates!"
  450. echo -e "$(date '+%b %d %H:%M:%S') ${servicename}: Monitor detected ${servername} is currently checking for updates!" >> ${scriptlog}
  451. echo -e "[\e[0;36m INFO \e[0;39m] ${servicename}: ${servername} will start when updating is complete"
  452. echo -e "$(date '+%b %d %H:%M:%S') ${servicename}: ${servername} will start when updating is complete" >> ${scriptlog}
  453. fi
  454. }
  455. fn_updateserver(){
  456. fn_rootcheck
  457. fn_syscheck
  458. echo -e "[\e[0;32m OK \e[0;39m] Updating ${servicename}: ${servername}"
  459. echo -e "$(date '+%b %d %H:%M:%S') ${servicename}: Updating ${servername}" >> ${scriptlog}
  460. cd ${rootdir}
  461. cd steamcmd
  462. ./steamcmd.sh +login ${steamuser} ${steampass} +force_install_dir ${filesdir} +app_update ${appid} validate +quit |tee -a ${logfile}
  463. if [ $(grep Denied ${logfile}|wc -l) -ge 1 ];then
  464. echo -e "[\e[0;31m FAIL \e[0;39m] ${servicename}: STEAMAUTH error detected!: Server update failed"
  465. echo -e "$(date '+%b %d %H:%M:%S') ${servicename}: STEAMAUTH error detected!: Server update failed" >> ${logfile}
  466. if [ "${emailnotification}" = "on" ];then
  467. mail -s "${servername}: Steam Auth Failure" ${email}< ${logfile}
  468. fi
  469. fi
  470. }
  471. fn_restartserver(){
  472. echo -e "$(date '+%b %d %H:%M:%S') ${servicename}: Restarting ${servername}" >> ${scriptlog}
  473. fn_stopserver
  474. fn_startserver
  475. }
  476. fn_stopserver(){
  477. fn_rootcheck
  478. fn_syscheck
  479. pid=$(tmux list-sessions 2>&1|awk '{print $1}'|grep ${servicename}|wc -l)
  480. echo -en "[ .... ] Stopping ${servicename}: ${servername}"
  481. echo -e "$(date '+%b %d %H:%M:%S') ${servicename}: Stopping ${servername}" >> ${scriptlog}
  482. sleep 0.5
  483. if [ "${pid}" == "0" ];then
  484. echo -en "\r[\e[0;31m FAIL \e[0;39m] Stopping ${servicename}: ${servername} is already stopped"
  485. echo -e "$(date '+%b %d %H:%M:%S') ${servicename}: ${servername} is already stopped" >> ${scriptlog}
  486. else
  487. tmux kill-session -t ${servicename}
  488. echo -en "\r[\e[0;32m OK \e[0;39m] Stopping ${servicename}: ${servername}"
  489. echo -e "$(date '+%b %d %H:%M:%S') ${servicename}: Stopped ${servername}" >> ${scriptlog}
  490. fi
  491. sleep 0.5
  492. echo -en "\n"
  493. }
  494. fn_startserver(){
  495. fn_rootcheck
  496. fn_syscheck
  497. echo -en "[ .... ] Starting ${servicename}: ${servername}"
  498. echo -e "$(date '+%b %d %H:%M:%S') ${servicename}: Starting ${servername}" >> ${scriptlog}
  499. sleep 0.5
  500. fn_runcheck
  501. fn_logmanager
  502. mv ${scriptlog} ${scriptlogdate}
  503. mv ${consolelog} ${consolelogdate}
  504. cd ${systemdir}
  505. tmux new-session -d -s ${servicename} "./ucc-bin ${parms} |tee -a ${consolelog}"
  506. sleep 1
  507. tmuxwc=$(tmux list-sessions 2>&1|awk '{print $1}'|grep ${servicename}|wc -l)
  508. if [ ${tmuxwc} -eq 0 ];then
  509. echo -en "\r[\e[0;31m FAIL \e[0;39m] Starting ${servicename}: Failed to start ${servername}"
  510. echo -e "$(date '+%b %d %H:%M:%S') ${servicename}: failed to start ${servername}" >> ${scriptlog}
  511. else
  512. echo -en "\r[\e[0;32m OK \e[0;39m] Starting ${servicename}: ${servername}"
  513. echo -e "$(date '+%b %d %H:%M:%S') ${servicename}: Started ${servername}" >> ${scriptlog}
  514. fi
  515. sleep 0.5
  516. echo -en "\n"
  517. }
  518. #
  519. ## Installer
  520. #
  521. fn_header(){
  522. clear
  523. echo "================================="
  524. echo "${gamename}"
  525. echo "Server Linux Installer"
  526. echo "by Daniel Gibbs"
  527. echo "http://danielgibbs.co.uk"
  528. echo "================================="
  529. echo ""
  530. }
  531. fn_steamdl(){
  532. echo "Installing Steam"
  533. echo "================================="
  534. cd ${rootdir}
  535. mkdir steamcmd
  536. cd steamcmd
  537. if [ ! -f steam.sh ];then
  538. wget http://media.steampowered.com/client/steamcmd_linux.tar.gz
  539. tar --verbose -zxf steamcmd_linux.tar.gz
  540. rm -v steamcmd_linux.tar.gz
  541. chmod +x steam.sh
  542. else
  543. echo "Steam already installed!"
  544. fi
  545. }
  546. fn_retryinstall(){
  547. while true; do
  548. read -p "Retry install? [y/N]" yn
  549. case $yn in
  550. [Yy]* ) fn_install;;
  551. [Nn]* ) echo Exiting; exit ;;
  552. * ) echo "Please answer yes or no.";;
  553. esac
  554. done
  555. }
  556. fn_install(){
  557. fn_rootcheck
  558. fn_header
  559. if [ -d ${systemdir} ];then
  560. echo "${gamename} Server is already installed here:"
  561. pwd
  562. echo ""
  563. while true; do
  564. read -p "Continue [y/N]" yn
  565. case $yn in
  566. [Yy]* ) break;;
  567. [Nn]* ) echo Exiting; return 1 ;;
  568. * ) echo "Please answer yes or no.";;
  569. esac
  570. done
  571. fi
  572. fn_header
  573. echo "Install Directory:"
  574. pwd
  575. echo ""
  576. while true; do
  577. read -p "Continue [y/N]" yn
  578. case $yn in
  579. [Yy]* ) break;;
  580. [Nn]* ) echo Exiting; return 1 ;;
  581. * ) echo "Please answer yes or no.";;
  582. esac
  583. done
  584. fn_header
  585. fn_steamdl
  586. echo ""
  587. echo "Installing ${gamename} Server"
  588. echo "================================="
  589. cd ${rootdir}/steamcmd
  590. mkdir -v ${filesdir}
  591. touch install.txt
  592. chmod 0600 install.txt
  593. echo "login ${steamuser} ${steampass}" > install.txt
  594. echo "force_install_dir ${filesdir}" >> install.txt
  595. echo "app_update ${appid} validate" >> install.txt
  596. echo "quit" >> install.txt
  597. STEAMEXE=steamcmd ./steam.sh +runscript install.txt
  598. rm install.txt
  599. echo ""
  600. echo "================================="
  601. while true; do
  602. read -p "Was the install successful? [y/N]" yn
  603. case $yn in
  604. [Yy]* ) break;;
  605. [Nn]* ) fn_retryinstall ;;
  606. * ) echo "Please answer yes or no.";;
  607. esac
  608. done
  609. fn_header
  610. echo "Configuring ${gamename} Server"
  611. echo "================================="
  612. sleep 1
  613. echo "Copying ${systemdir}/default.ini to ${systemdir}/${ini}"
  614. cp ${systemdir}/Default.ini ${systemdir}/${ini}
  615. sleep 1
  616. echo "Creating log directorys"
  617. mkdir -v ${rootdir}/log
  618. mkdir -v ${scriptlogdir}
  619. mkdir -v ${consolelogdir}
  620. touch ${consolelog}
  621. sleep 1
  622. echo "Applying WebAdmin ROOst.css fix!"
  623. echo "http://forums.tripwireinteractive.com/showpost.php?p=585435&postcount=13"
  624. sed -i 's/none}/none;/g' ${filesdir}/Web/ServerAdmin/ROOst.css
  625. sed -i 's/underline}/underline;/g' ${filesdir}/Web/ServerAdmin/ROOst.css
  626. sleep 1
  627. echo "Applying WebAdmin CharSet fix!"
  628. echo "http://forums.tripwireinteractive.com/showpost.php?p=442340&postcount=1"
  629. sed -i 's/CharSet="iso-8859-1"/CharSet="utf-8"/g' ${systemdir}/UWeb.int
  630. sleep 1
  631. echo "Setting WebAdmin username and password"
  632. sed -i 's/AdminName=/AdminName=admin/g' ${systemdir}/${ini}
  633. sed -i 's/AdminPassword=/AdminPassword=kfpass/g' ${systemdir}/${ini}
  634. sleep 1
  635. echo "Enabling WebAdmin"
  636. sed -i 's/bEnabled=False/bEnabled=True/g' ${systemdir}/${ini}
  637. sleep 1
  638. echo "Forcing server to start to get ports/server name to display correctly"
  639. sleep 1
  640. cd ${rootdir}
  641. ${selfname} start
  642. sleep 5
  643. ${selfname} restart
  644. sleep 5
  645. ${selfname} stop
  646. sleep 5
  647. fn_header
  648. fn_details
  649. echo "================================="
  650. echo "Install Complete!"
  651. echo ""
  652. echo "To start server type:"
  653. echo "${selfname} start"
  654. echo ""
  655. }
  656. case "$1" in
  657. start)
  658. fn_startserver;;
  659. stop)
  660. fn_stopserver;;
  661. restart)
  662. fn_restartserver;;
  663. update)
  664. fn_stopserver
  665. fn_updateserver
  666. fn_startserver;;
  667. monitor)
  668. fn_monitorserver;;
  669. email-test)
  670. fn_emailtest;;
  671. details)
  672. fn_details;;
  673. backup)
  674. fn_backupserver;;
  675. console)
  676. fn_console;;
  677. debug)
  678. fn_debugserver;;
  679. install)
  680. fn_install;;
  681. map-compressor)
  682. fn_compressmaps;;
  683. steam-auth)
  684. fn_updateserver
  685. fn_steamguard;;
  686. *)
  687. echo "Usage: $0 {start|stop|restart|update|monitor|email-test|details|backup|console|debug|install|map-compressor|steam-auth}"
  688. exit 1;;
  689. esac
  690. exit