roserver 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604
  1. #!/bin/bash
  2. # Red Orchestra: Ostfront 41-45
  3. # Server Management Script
  4. # Author: Daniel Gibbs
  5. # Website: http://danielgibbs.co.uk
  6. # Version: 310813
  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="223250"
  17. # Directorys
  18. rootdir="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
  19. selfname="$0"
  20. filesdir="${rootdir}/serverfiles"
  21. systemdir="${filesdir}/system"
  22. compressedmapsdir="${rootdir}/Maps-Compressed"
  23. # Server names
  24. servicename="ro-server"
  25. gamename="Red Orchestra: Ostfront 41-45"
  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="RO-Arad.rom"
  36. parms="server ${defaultmap}?game=ROGame.ROTeamGame?VACSecured=true -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. webadminport=$(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} UDP Port=${gameport}"
  355. echo "INBOUND Query Port ${queryport} UDP n/a"
  356. if [ "${appid}" != "223250" ];then
  357. echo "INBOUND GameSpy Query Port ${gsqueryport} UDP OldQueryPortNumber=${gsqueryport}"
  358. fi
  359. if [ "${appid}" == "215360" ];then
  360. echo "OUTBOUND Master Server port 28852 TCP/UDP n/a"
  361. else
  362. echo "OUTBOUND Master Server port 28900/28902 TCP/UDP n/a"
  363. fi
  364. if [ "${appid}" ];then
  365. if [ "${appid}" == "223250" ];then
  366. echo "OUTBOUND Steam Port 20610 UDP n/a"
  367. else
  368. echo "OUTBOUND Steam Port 20660 UDP n/a"
  369. fi
  370. fi
  371. echo "INBOUND WebAdmin ${webadminport} TCP ListenPort=${webadminport}"
  372. echo ""
  373. echo "${servername} WebAdmin"
  374. echo "======================="
  375. echo "WebAdmin URL: http://localhost:${webadminport}"
  376. echo "WebAdmin Username: ${webadminuser}"
  377. echo "WebAdmin Password: ${webadminpass}"
  378. echo ""
  379. echo "Config file"
  380. echo "${systemdir}/${ini}"
  381. elif [ "${engine}" = "source" ]||[ "${engine}" = "goldsource" ];then
  382. servername=`grep -s hostname ${servercfg} | sed 's/hostname //g'|sed 's/"//g'`
  383. rcon=`grep -s rcon_password ${servercfg} | sed 's/rcon_password //g'|sed 's/"//g'`
  384. echo "Ports the server is currently using"
  385. echo ""
  386. echo "DIRECTION DESCRIPTION PORT"
  387. echo "INBOUND Game/Rcon Port ${port}"
  388. if [ "${engine}" = "source" ];then
  389. echo "INBOUND SourceTV Port ${sourcetvport}"
  390. fi
  391. echo "OUTBOUND Client Port ${clientport}"
  392. echo ""
  393. echo "You can change ports by editing the"
  394. echo "start parameters in ${selfname}"
  395. echo ""
  396. echo "${servername} Details"
  397. echo "======================="
  398. echo "Server name: ${servername}"
  399. echo "Rcon Password: ${rcon}"
  400. echo ""
  401. echo "Config file:"
  402. echo "${servercfg}"
  403. fi
  404. echo ""
  405. }
  406. #
  407. ## Installer
  408. #
  409. fn_header(){
  410. clear
  411. echo "================================="
  412. echo "${gamename}"
  413. echo "Server Linux Installer"
  414. echo "by Daniel Gibbs"
  415. echo "http://danielgibbs.co.uk"
  416. echo "================================="
  417. echo ""
  418. }
  419. fn_steamdl(){
  420. echo "Installing Steam"
  421. echo "================================="
  422. cd ${rootdir}
  423. mkdir steamcmd
  424. cd steamcmd
  425. if [ ! -f steam.sh ];then
  426. wget http://media.steampowered.com/client/steamcmd_linux.tar.gz
  427. tar --verbose -zxf steamcmd_linux.tar.gz
  428. rm -v steamcmd_linux.tar.gz
  429. chmod +x steam.sh
  430. else
  431. echo "Steam already installed!"
  432. fi
  433. }
  434. fn_retryinstall(){
  435. while true; do
  436. read -p "Retry install? [y/N]" yn
  437. case $yn in
  438. [Yy]* ) fn_install;;
  439. [Nn]* ) echo Exiting; exit ;;
  440. * ) echo "Please answer yes or no.";;
  441. esac
  442. done
  443. }
  444. fn_install(){
  445. fn_rootcheck
  446. fn_header
  447. if [ -d ${systemdir} ];then
  448. echo "${gamename} Server is already installed here:"
  449. pwd
  450. echo ""
  451. while true; do
  452. read -p "Continue [y/N]" yn
  453. case $yn in
  454. [Yy]* ) break;;
  455. [Nn]* ) echo Exiting; return 1 ;;
  456. * ) echo "Please answer yes or no.";;
  457. esac
  458. done
  459. fi
  460. fn_header
  461. echo "Install Directory:"
  462. pwd
  463. echo ""
  464. while true; do
  465. read -p "Continue [y/N]" yn
  466. case $yn in
  467. [Yy]* ) break;;
  468. [Nn]* ) echo Exiting; return 1 ;;
  469. * ) echo "Please answer yes or no.";;
  470. esac
  471. done
  472. fn_header
  473. fn_steamdl
  474. echo ""
  475. echo "Installing ${gamename} Server"
  476. echo "================================="
  477. cd ${rootdir}/steamcmd
  478. mkdir -v ${filesdir}
  479. touch install.txt
  480. chmod 0600 install.txt
  481. echo "login ${steamuser} ${steampass}" > install.txt
  482. echo "force_install_dir ${filesdir}" >> install.txt
  483. echo "app_update ${appid} validate" >> install.txt
  484. echo "quit" >> install.txt
  485. STEAMEXE=steamcmd ./steam.sh +runscript install.txt
  486. rm install.txt
  487. echo ""
  488. echo "================================="
  489. while true; do
  490. read -p "Was the install successful? [y/N]" yn
  491. case $yn in
  492. [Yy]* ) break;;
  493. [Nn]* ) fn_retryinstall ;;
  494. * ) echo "Please answer yes or no.";;
  495. esac
  496. done
  497. fn_header
  498. echo "Configuring ${gamename} Server"
  499. echo "================================="
  500. sleep 1
  501. echo "Copying ${systemdir}/default.ini to ${systemdir}/${ini}"
  502. cp ${systemdir}/default.ini ${systemdir}/${ini}
  503. sleep 1
  504. echo "Creating log directory"
  505. mkdir -v ${logdir}
  506. sleep 1
  507. echo "Applying WebAdmin ROOst.css fix!"
  508. echo "http://forums.tripwireinteractive.com/showpost.php?p=585435&postcount=13"
  509. sed -i 's/none}/none;/g' ${filesdir}/Web/ServerAdmin/ROOst.css
  510. sed -i 's/underline}/underline;/g' ${filesdir}/Web/ServerAdmin/ROOst.css
  511. sleep 1
  512. echo "Applying WebAdmin CharSet fix!"
  513. echo "http://forums.tripwireinteractive.com/showpost.php?p=442340&postcount=1"
  514. sed -i 's/CharSet="iso-8859-1"/CharSet="utf-8"/g' ${systemdir}/uweb.int
  515. sleep 1
  516. echo "Setting WebAdmin username and password"
  517. sed -i 's/AdminName=/AdminName=admin/g' ${systemdir}/${ini}
  518. sed -i 's/AdminPassword=/AdminPassword=ropass/g' ${systemdir}/${ini}
  519. sleep 1
  520. echo "Enabling WebAdmin"
  521. sed -i 's/bEnabled=False/bEnabled=True/g' ${systemdir}/${ini}
  522. sleep 1
  523. echo "Forcing server to start to get ports/server name to display correctly"
  524. sleep 1
  525. cd ${rootdir}
  526. ${selfname} start
  527. sleep 5
  528. ${selfname} restart
  529. sleep 5
  530. ${selfname} stop
  531. sleep 5
  532. fn_header
  533. fn_details
  534. echo "================================="
  535. echo "Install Complete!"
  536. echo ""
  537. echo "To start server type:"
  538. echo "${selfname} start"
  539. echo ""
  540. }
  541. case "$1" in
  542. start)
  543. fn_startserver;;
  544. stop)
  545. fn_stopserver;;
  546. restart)
  547. fn_restartserver;;
  548. update)
  549. fn_stopserver
  550. fn_updateserver
  551. fn_startserver;;
  552. monitor)
  553. fn_monitorserver;;
  554. install)
  555. fn_install;;
  556. debug)
  557. fn_debugserver;;
  558. map-compressor)
  559. fn_compressmaps;;
  560. steam-auth)
  561. fn_updateserver
  562. fn_steamguard;;
  563. email-test)
  564. fn_emailtest;;
  565. details)
  566. fn_details;;
  567. *)
  568. echo "Usage: $0 {start|stop|restart|update|monitor|install|debug|map-compressor|steam-auth|email-test|details}"
  569. exit 1;;
  570. esac
  571. exit