kfserver 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592
  1. #!/bin/bash
  2. # Killing Floor
  3. # Server Management Script
  4. # Author: Daniel Gibbs
  5. # Website: http://danielgibbs.co.uk
  6. # Version: 300813
  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}/killingfloor"
  21. systemdir="${filesdir}/System"
  22. compressedmapsdir="${rootdir}/Maps-Compressed"
  23. # Server names
  24. servicename="kf-server"
  25. gamename="Killing Floor"
  26. engine="unreal2"
  27. ini="${servicename}.ini"
  28. servername=`grep -s ServerName= ${systemdir}/${ini} | sed 's/ServerName=//g'`
  29. # Logging
  30. logdir="${rootdir}/log"
  31. logfile="${logdir}/${servicename}.log"
  32. logfiledate="${logdir}/${servicename}-$( date '+%d-%m-%Y-%H-%M-%S').log"
  33. logdays="7"
  34. # Start vars
  35. defaultmap="KF-BioticsLab.rom"
  36. parms="server ${defaultmap}?game=KFmod.KFGameType -nohomedir ini=${ini} log=${logfile}"
  37. ##### Script #####
  38. # Do not edit
  39. # unless you know
  40. # what you are doing
  41. fn_rootcheck(){
  42. if [ `whoami` = "root" ];then
  43. echo -e "[\e[0;31m FAIL \e[0;39m] Script will not run as root!"
  44. exit
  45. fi
  46. }
  47. fn_syscheck(){
  48. if [ ! -e ${systemdir} ];then
  49. echo -e "[\e[0;31m FAIL \e[0;39m] Cannot access ${systemdir}: No such directory"
  50. exit
  51. fi
  52. }
  53. fn_serverquery(){
  54. # uses serverquery.py to directly query the server
  55. # detects if the server locks up
  56. if [ -f serverquery.py ];then
  57. echo -e "[\e[0;36m INFO \e[0;39m] serverquery.py detected"
  58. echo -e "$( date '+%b %d %H:%M:%S') ${servicename}: serverquery.py detected" >> ${logfile}
  59. echo -e "[\e[0;32m OK \e[0;39m] Querying ${servicename}: ${servername}: QUERYING"
  60. echo -e "$( date '+%b %d %H:%M:%S') ${servicename}: Querying ${servername}: QUERYING" >> ${logfile}
  61. serverquery=`./serverquery.py 127.0.0.1 ${port} 2>&1`
  62. sleep 1
  63. if [ "${serverquery}" = "ERROR 1" ]||[ "${serverquery}" = "ERROR 2" ]||[ "${serverquery}" = "ERROR 3" ];then
  64. echo -e "[\e[0;31m FAIL \e[0;39m] Querying ${servicename}: ${servername}: ${serverquery}"
  65. echo -e "$( date '+%b %d %H:%M:%S') ${servicename}: Querying ${servername}: ${serverquery}" >> ${logfile}
  66. sleep 1
  67. echo -e "[\e[1;33m WARN \e[0;39m] ${servicename}: Monitor detected ${servername} has locked up!"
  68. echo -e "$( date '+%b %d %H:%M:%S') ${servicename}: Monitor detected ${servername} has locked up!" >> ${logfile}
  69. sleep 1
  70. fn_restartserver
  71. else
  72. echo -e "[\e[0;32m OK \e[0;39m] Querying ${servicename}: ${servername}: ${serverquery}"
  73. echo -e "$( date '+%b %d %H:%M:%S') ${servicename}: Querying ${servername}: ${serverquery}" >> ${logfile}
  74. sleep 1
  75. fi
  76. fi
  77. }
  78. fn_runcheck(){
  79. # already running check
  80. pidwc=`screen -ls |grep ${servicename} |awk -F . '{print $1}'|awk '{print $1}'|wc -l`
  81. if [ ${pidwc} -eq 1 ];then
  82. fn_serverquery
  83. echo -e "[\e[0;36m INFO \e[0;39m] ${servicename}: ${servername} is already running"
  84. echo -e "$( date '+%b %d %H:%M:%S') ${servicename}: ${servername} is already running" >> ${logfile}
  85. exit
  86. # multiple of same instance check
  87. elif [ ${pidwc} -ge 2 ];then
  88. echo -e "[\e[0;31m FAIL \e[0;39m] ${servicename}: ${servername} is running ${pidwc} times"
  89. echo -e "$( date '+%b %d %H:%M:%S') ${servicename}: ${servername} is running ${pidwc} times" >> ${logfile}
  90. echo -e "[\e[0;32m OK \e[0;39m] ${servicename}: Stopping ${pidwc} instances of ${servername}"
  91. echo -e "$( date '+%b %d %H:%M:%S') ${servicename}: Stopping ${pidwc} instances of ${servername}" >> ${logfile}
  92. fn_stopserver
  93. exit
  94. fi
  95. }
  96. fn_distro(){
  97. arch=$(uname -m)
  98. kernel=$(uname -r)
  99. if [ -f /etc/lsb-release ]; then
  100. os=$(lsb_release -s -d)
  101. elif [ -f /etc/debian_version ]; then
  102. os="Debian $(cat /etc/debian_version)"
  103. elif [ -f /etc/redhat-release ]; then
  104. os=`cat /etc/redhat-release`
  105. else
  106. os="$(uname -s) $(uname -r)"
  107. fi
  108. }
  109. fn_uptime(){
  110. uptime=$(</proc/uptime)
  111. uptime=${uptime%%.*}
  112. minutes=$(( uptime/60%60 ))
  113. hours=$(( uptime/60/60%24 ))
  114. days=$(( uptime/60/60/24 ))
  115. }
  116. fn_load(){
  117. load=$(uptime | awk -F 'load average' '{ print $2 }')
  118. }
  119. fn_emailnotification(){
  120. fn_distro
  121. fn_uptime
  122. fn_load
  123. {
  124. echo -e "=========================================\nServer information\n=========================================\n"
  125. echo -e "Date: $(date)"
  126. echo -e "Distro: ${os}"
  127. echo -e "Arch: ${arch}"
  128. echo -e "Kernel: ${kernel}"
  129. echo -e "Hostname: $HOSTNAME"
  130. echo -e "Uptime: ${days}d, ${hours}h, ${minutes}m"
  131. echo -e "Avg Load${load}\n"
  132. echo -e "=========================================\n${servicename} statistics\n=========================================\n"
  133. echo -e "Service: ${servicename}"
  134. echo -e "Server: ${servername}"
  135. echo -e "Failure reason: ${failurereason}"
  136. echo -e "Action Taken: ${actiontaken}\n"
  137. echo -e "=========================================\n${servicename} log summary\n=========================================\n"
  138. }|tee ${logdir}/${servicename}-email.log > /dev/null 2>&1
  139. tail -50 ${logfile} >> /${logdir}/${servicename}-email.log
  140. mail -s "${subject}" ${email} < /${logdir}/${servicename}-email.log
  141. echo -e "[\e[0;36m INFO \e[0;39m] Sent email notification to ${email}"
  142. echo -e "$( date '+%b %d %H:%M:%S') ${servicename}: sent email notification to ${email}" >> ${logfile}
  143. }
  144. fn_emailtest(){
  145. fn_rootcheck
  146. fn_syscheck
  147. echo -e "[\e[0;32m OK \e[0;39m] Emailing test notification"
  148. echo -e "$( date '+%b %d %H:%M:%S') ${servicename}: Emailing test notification" >> ${logfile}
  149. if [ "${emailnotification}" = "on" ];then
  150. subject="${servicename} Email Test Notification - Testing ${servername}"
  151. failurereason="Testing ${servicename} email notification"
  152. actiontaken="Sent test email...hello is this thing on?"
  153. fn_emailnotification
  154. else
  155. echo -e "[\e[0;31m FAIL \e[0;39m] Email notificaion not enabled"
  156. echo -e "$( date '+%b %d %H:%M:%S') ${servicename}: Email notificaion not enabled" >> ${logfile}
  157. fi
  158. }
  159. fn_logmanager(){
  160. # log manager will active if finds logs older than $logdays
  161. if [ `find ${logdir}/* -mtime +${logdays} |wc -l` -ne "0" ];then
  162. echo -e "[\e[0;32m OK \e[0;39m] Starting log cleaner"
  163. echo -e "$( date '+%b %d %H:%M:%S') ${servicename}: Starting log cleaner" >> ${logfile}
  164. echo -e "[\e[0;36m INFO \e[0;39m] Removing logs older than ${logdays} days"
  165. echo -e "$( date '+%b %d %H:%M:%S') ${servicename}: Removing logs older than ${logdays} days" >> ${logfile}
  166. find ${logdir}/* -mtime +${logdays} |tee >> ${logfile}
  167. count=`find ${logdir}/* -mtime +${logdays}|wc -l`
  168. find ${logdir}/* -mtime +${logdays} -exec rm {} \;
  169. echo -e "[\e[0;36m INFO \e[0;39m] Log cleaner removed ${count} log files"
  170. echo -e "$( date '+%b %d %H:%M:%S') ${servicename}: Log cleaner removed ${count} log files" >> ${logfile}
  171. fi
  172. }
  173. fn_restartserver(){
  174. echo -e "[\e[0;32m OK \e[0;39m] Restarting ${servicename}: ${servername}"
  175. echo -e "$( date '+%b %d %H:%M:%S') ${servicename}: Restarting ${servername}" >> ${logfile}
  176. fn_stopserver
  177. sleep 1
  178. fn_startserver
  179. }
  180. fn_startserver(){
  181. fn_rootcheck
  182. fn_syscheck
  183. fn_runcheck
  184. fn_logmanager
  185. cd ${systemdir}
  186. echo -e "[\e[0;32m OK \e[0;39m] Starting ${servicename}: ${servername}"
  187. echo -e "$( date '+%b %d %H:%M:%S') ${servicename}: Starting ${servername}" >> ${logfile}
  188. cp ${logfile} ${logfiledate}
  189. screen -d -m -S ${servicename} ./ucc-bin ${parms}
  190. sleep 1
  191. pidwc=`screen -ls |grep ${servicename} |awk -F . '{print $1}'|awk '{print $1}'|wc -l`
  192. if [ ${pidwc} -eq 0 ];then
  193. echo -e "[\e[0;31m FAIL \e[0;39m] ${servicename}: Failed to start ${servername}"
  194. echo -e "$( date '+%b %d %H:%M:%S') ${servicename}: failed to start ${servername}" >> ${logfile}
  195. fi
  196. }
  197. fn_stopserver(){
  198. fn_rootcheck
  199. fn_syscheck
  200. pid=`screen -ls |grep ${servicename} |awk -F . '{print $1}'|awk '{print $1}'`
  201. if [ -z ${pid} ];then
  202. echo -e "[\e[0;36m INFO \e[0;39m] ${servicename}: ${servername} is already stopped"
  203. echo -e "$( date '+%b %d %H:%M:%S') ${servicename}: ${servername} is already stopped" >> ${logfile}
  204. else
  205. echo -e "[\e[0;32m OK \e[0;39m] Stopping ${servicename}: ${servername}"
  206. echo -e "$( date '+%b %d %H:%M:%S') ${servicename}: Stopping ${servername}" >> ${logfile}
  207. kill `screen -ls |grep ${servicename} |awk -F . '{print $1}'|awk '{print $1}'`
  208. screen -wipe > /dev/null 2>&1
  209. fi
  210. }
  211. fn_debugserver(){
  212. fn_rootcheck
  213. fn_syscheck
  214. cd ${filesdir}
  215. echo -e "[\e[0;32m OK \e[0;39m] Starting ${servicename}: ${servername} in debug mode!"
  216. sleep 0.5
  217. echo -e ""
  218. echo -e "Use for identifying server issues only!"
  219. while true; do
  220. echo "If server is already running it will be stopped"
  221. read -p "Continue? [y/N]" yn
  222. case $yn in
  223. [Yy]* ) break;;
  224. [Nn]* ) echo Exiting; return 1 ;;
  225. * ) echo "Please answer yes or no.";;
  226. esac
  227. done
  228. fn_stopserver
  229. sleep 1
  230. echo -e "[\e[0;36m INFO \e[0;39m] Press CTRL+C to drop out of debug mode"
  231. sleep 3
  232. echo -e "[\e[0;32m OK \e[0;39m] Starting ${servicename}: ${servername}"
  233. cd ${systemdir}
  234. ./ucc-bin ${parms}
  235. }
  236. fn_monitorserver(){
  237. fn_rootcheck
  238. fn_syscheck
  239. fn_logmanager
  240. echo -e "[\e[0;32m OK \e[0;39m] Checking ${servicename}: ${servername}"
  241. echo -e "$( date '+%b %d %H:%M:%S') ${servicename}: Checking ${servername}" >> ${logfile}
  242. updatecheck=`ps -ef|grep "${selfname} update"|grep -v grep|wc -l`
  243. if [ "${updatecheck}" = "0" ];then
  244. fn_runcheck
  245. echo -e "[\e[1;33m WARN \e[0;39m] ${servicename}: Monitor detected ${servername} had stopped!"
  246. echo -e "$( date '+%b %d %H:%M:%S') ${servicename}: Monitor detected ${servername} had stopped!" >> ${logfile}
  247. if [ "${emailnotification}" = "on" ];then
  248. subject="${servicename} Monitor - Starting ${servername}"
  249. failurereason="${servername} had stopped"
  250. actiontaken="restarted ${servername}"
  251. fn_emailnotification
  252. fi
  253. fn_startserver
  254. else
  255. echo -e "[\e[0;36m INFO \e[0;39m] ${servicename}: Monitor detected ${servername} is currently checking for updates!"
  256. echo -e "$( date '+%b %d %H:%M:%S') ${servicename}: Monitor detected ${servername} is currently checking for updates!" >> ${logfile}
  257. echo -e "[\e[0;36m INFO \e[0;39m] ${servicename}: ${servername} will start when updating is complete"
  258. echo -e "$( date '+%b %d %H:%M:%S') ${servicename}: ${servername} will start when updating is complete" >> ${logfile}
  259. fi
  260. }
  261. fn_updateserver(){
  262. fn_rootcheck
  263. fn_syscheck
  264. echo -e "[\e[0;32m OK \e[0;39m] Updating ${servicename}: ${servername}"
  265. echo -e "$( date '+%b %d %H:%M:%S') ${servicename}: Updating ${servername}" >> ${logfile}
  266. cd ${rootdir}
  267. cd steamcmd
  268. ./steamcmd.sh +login ${steamuser} ${steampass} +force_install_dir ${filesdir} +app_update ${appid} validate +quit |tee -a ${logfile}
  269. if [ $(grep Denied ${logfile}|wc -l) -ge 1 ];then
  270. echo -e "[\e[0;31m FAIL \e[0;39m] ${servicename}: STEAMAUTH error detected!: Server update failed"
  271. echo -e "$( date '+%b %d %H:%M:%S') ${servicename}: STEAMAUTH error detected!: Server update failed" >> ${logfile}
  272. if [ "${emailnotification}" = "on" ];then
  273. mail -s "${servername}: Steam Auth Failure" ${email}< ${logfile}
  274. fi
  275. fi
  276. }
  277. fn_compressmaps(){
  278. fn_rootcheck
  279. clear
  280. echo "${gamename} Map Compressor"
  281. echo "============================"
  282. echo "Will compress all maps in:"
  283. echo ""
  284. pwd
  285. echo ""
  286. echo "Compressed maps saved to:"
  287. echo ""
  288. echo "$compressedmapsdir"
  289. echo ""
  290. while true; do
  291. read -p "Start compression [y/N]" yn
  292. case $yn in
  293. [Yy]* ) break;;
  294. [Nn]* ) echo Exiting; return 1 ;;
  295. * ) echo "Please answer yes or no.";;
  296. esac
  297. done
  298. mkdir $compressedmapsdir
  299. rm -rfv ${filesdir}/Maps/*.uz2
  300. cd ${systemdir}
  301. ./ucc-bin compress ../Maps/* --nohomedir
  302. mv -fv ${filesdir}/Maps/*.uz2 $compressedmapsdir
  303. }
  304. fn_steamguard(){
  305. fn_rootcheck
  306. fn_syscheck
  307. clear
  308. fn_header
  309. fn_steamdl
  310. clear
  311. fn_header
  312. echo "If you are gettng an error:"
  313. echo ""
  314. echo "Login Failure: Account Logon Denied Failed."
  315. echo ""
  316. echo "You should now get an email from Steam with a Steam Guard code"
  317. echo ""
  318. read -p "Press [Enter] key to when you have the code..."
  319. clear
  320. fn_header
  321. echo "Please enter Steam Guard Code"
  322. echo "=============================="
  323. echo -n "Code: "
  324. read CODE
  325. touch guard.txt
  326. chmod 0600 guard.txt
  327. echo "set_steam_guard_code $CODE" > guard.txt
  328. echo "login ${steamuser} ${steampass}" >> guard.txt
  329. echo "quit" >> guard.txt
  330. STEAMEXE=steamcmd ./steam.sh +runscript guard.txt
  331. rm guard.txt
  332. cd ../
  333. echo "=============================="
  334. echo "Complete!"
  335. cd ${rootdir}
  336. }
  337. fn_details(){
  338. echo ""
  339. echo "${gamename} Server Details"
  340. echo "============================"
  341. echo ""
  342. echo "${servername} Ports"
  343. echo "======================="
  344. if [ "${engine}" = "unreal2" ];then
  345. gameport=$(grep Port= ${systemdir}/${ini}|grep -v Master|grep -v LAN|grep -v Proxy|grep -v Listen|sed 's/\Port=//g')
  346. queryport=$((${gameport} + 1))
  347. gsqueryport=$(grep OldQueryPortNumber= ${systemdir}/${ini}|sed 's/\OldQueryPortNumber=//g')
  348. webadmin=$(grep ListenPort= ${systemdir}/${ini}|sed 's/\ListenPort=//g')
  349. webadminuser=$(grep AdminName= ${systemdir}/${ini}|sed 's/\AdminName=//g')
  350. webadminpass=$(grep AdminPassword= ${systemdir}/${ini}|sed 's/\AdminPassword=//g')
  351. echo "Ports the server is currently using"
  352. echo ""
  353. echo "DIRECTION DESCRIPTION PORT INI VARIABLE"
  354. echo "INBOUND Game Port ${gameport} Port=${gameport}"
  355. echo "INBOUND Query Port ${queryport} n/a"
  356. echo "INBOUND GameSpy Query Port ${gsqueryport} OldQueryPortNumber=${gsqueryport}"
  357. echo "OUTBOUND Master Server port 28900/28902 n/a"
  358. if [ "${appid}" ];then
  359. echo "OUTBOUND Steam Port 20660 n/a"
  360. fi
  361. echo "INBOUND: WebAdmin ${webadmin} ListenPort=${webadmin}"
  362. echo ""
  363. echo "${servername} WebAdmin"
  364. echo "======================="
  365. echo "WebAdmin URL: http://localhost:${webadmin}"
  366. echo "WebAdmin Username: ${webadminuser}"
  367. echo "WebAdmin Password: ${webadminpass}"
  368. echo ""
  369. echo "Config file"
  370. echo "${systemdir}/${ini}"
  371. elif [ "${engine}" = "source" ];then
  372. servername=`grep -s hostname ${servercfg} | sed 's/hostname //g'|sed 's/"//g'`
  373. rcon=`grep -s rcon_password ${servercfg} | sed 's/rcon_password //g'|sed 's/"//g'`
  374. echo "Ports the server is currently using"
  375. echo ""
  376. echo "DIRECTION DESCRIPTION PORT"
  377. echo "INBOUND Game/Rcon Port ${port}"
  378. echo "INBOUND SourceTV Port ${sourcetvport}"
  379. echo "OUTBOUND Client Port ${clientport}"
  380. echo ""
  381. echo "You can change ports by editing the"
  382. echo "start parameters in ${selfname}"
  383. echo ""
  384. echo "${servername} Details"
  385. echo "======================="
  386. echo "Server name: ${servername}"
  387. echo "Rcon Password: ${rcon}"
  388. echo ""
  389. echo "Config file:"
  390. echo "${servercfg}"
  391. fi
  392. echo ""
  393. }
  394. #
  395. ##Installer
  396. #
  397. fn_header(){
  398. clear
  399. echo "================================="
  400. echo "${gamename}"
  401. echo "Server Linux Installer"
  402. echo "by Daniel Gibbs"
  403. echo "http://danielgibbs.co.uk"
  404. echo "================================="
  405. echo ""
  406. }
  407. fn_steamdl(){
  408. echo "Installing Steam"
  409. echo "================================="
  410. cd ${rootdir}
  411. mkdir steamcmd
  412. cd steamcmd
  413. if [ ! -f steam.sh ];then
  414. wget http://media.steampowered.com/client/steamcmd_linux.tar.gz
  415. tar --verbose -zxf steamcmd_linux.tar.gz
  416. rm -v steamcmd_linux.tar.gz
  417. chmod +x steam.sh
  418. else
  419. echo "Steam already installed!"
  420. fi
  421. }
  422. fn_retryinstall(){
  423. while true; do
  424. read -p "Retry install? [y/N]" yn
  425. case $yn in
  426. [Yy]* ) fn_install;;
  427. [Nn]* ) echo Exiting; exit ;;
  428. * ) echo "Please answer yes or no.";;
  429. esac
  430. done
  431. }
  432. fn_install(){
  433. fn_rootcheck
  434. fn_header
  435. if [ -d ${systemdir} ];then
  436. echo "${gamename} Server is already installed here:"
  437. pwd
  438. echo ""
  439. while true; do
  440. read -p "Continue [y/N]" yn
  441. case $yn in
  442. [Yy]* ) break;;
  443. [Nn]* ) echo Exiting; return 1 ;;
  444. * ) echo "Please answer yes or no.";;
  445. esac
  446. done
  447. fi
  448. fn_header
  449. echo "Install Directory:"
  450. pwd
  451. echo ""
  452. while true; do
  453. read -p "Continue [y/N]" yn
  454. case $yn in
  455. [Yy]* ) break;;
  456. [Nn]* ) echo Exiting; return 1 ;;
  457. * ) echo "Please answer yes or no.";;
  458. esac
  459. done
  460. fn_header
  461. fn_steamdl
  462. echo ""
  463. echo "Installing ${gamename} Server"
  464. echo "================================="
  465. cd ${rootdir}/steamcmd
  466. mkdir -v ${filesdir}
  467. touch install.txt
  468. chmod 0600 install.txt
  469. echo "login ${steamuser} ${steampass}" > install.txt
  470. echo "force_install_dir ${filesdir}" >> install.txt
  471. echo "app_update ${appid} validate" >> install.txt
  472. echo "quit" >> install.txt
  473. STEAMEXE=steamcmd ./steam.sh +runscript install.txt
  474. rm install.txt
  475. echo ""
  476. echo "================================="
  477. while true; do
  478. read -p "Was the install successful? [y/N]" yn
  479. case $yn in
  480. [Yy]* ) break;;
  481. [Nn]* ) fn_retryinstall ;;
  482. * ) echo "Please answer yes or no.";;
  483. esac
  484. done
  485. fn_header
  486. echo "Configuring ${gamename} Server"
  487. echo "================================="
  488. echo "Copying ${systemdir}/default.ini to ${systemdir}/${ini}"
  489. cp ${systemdir}/Default.ini ${systemdir}/${ini}
  490. sleep 1
  491. echo "Creating log directory"
  492. mkdir -v ${logdir}
  493. sleep 1
  494. echo "Applying WebAdmin ROOst.css fix!"
  495. echo "http://forums.tripwireinteractive.com/showpost.php?p=585435&postcount=13"
  496. sed -i 's/none}/none;/g' ${filesdir}/Web/ServerAdmin/ROOst.css
  497. sed -i 's/underline}/underline;/g' ${filesdir}/Web/ServerAdmin/ROOst.css
  498. sleep 1
  499. echo "Applying WebAdmin CharSet fix!"
  500. echo "http://forums.tripwireinteractive.com/showpost.php?p=442340&postcount=1"
  501. sed -i 's/CharSet="iso-8859-1"/CharSet="utf-8"/g' ${systemdir}/UWeb.int
  502. sleep 1
  503. echo "Setting WebAdmin username and password"
  504. sed -i 's/AdminName=/AdminName=admin/g' ${systemdir}/${ini}
  505. sed -i 's/AdminPassword=/AdminPassword=kfpass/g' ${systemdir}/${ini}
  506. sleep 1
  507. echo "Enabling WebAdmin"
  508. sed -i 's/bEnabled=False/bEnabled=True/g' ${systemdir}/${ini}
  509. sleep 1
  510. echo "Forcing server to start to get ports/server name to display correctly"
  511. sleep 1
  512. cd ${rootdir}
  513. ${selfname} start
  514. sleep 5
  515. ${selfname} restart
  516. sleep 5
  517. ${selfname} stop
  518. sleep 5
  519. fn_header
  520. fn_details
  521. echo "================================="
  522. echo "Install Complete!"
  523. echo ""
  524. echo "To start server type:"
  525. echo "${selfname} start"
  526. echo ""
  527. }
  528. case "$1" in
  529. start)
  530. fn_startserver;;
  531. stop)
  532. fn_stopserver;;
  533. restart)
  534. fn_restartserver;;
  535. update)
  536. fn_stopserver
  537. fn_updateserver
  538. fn_startserver;;
  539. monitor)
  540. fn_monitorserver;;
  541. install)
  542. fn_install;;
  543. debug)
  544. fn_debugserver;;
  545. map-compressor)
  546. fn_compressmaps;;
  547. steam-auth)
  548. fn_updateserver
  549. fn_steamguard;;
  550. email-test)
  551. fn_emailtest;;
  552. details)
  553. fn_details;;
  554. *)
  555. echo "Usage: $0 {start|stop|restart|update|monitor|install|debug|map-compressor|steam-auth|email-test|details}"
  556. exit 1;;
  557. esac
  558. exit