ut2k4server 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464
  1. #!/bin/bash
  2. # Unreal Tournament 2004
  3. # Server Management Script
  4. # Author: Daniel Gibbs
  5. # Website: http://danielgibbs.co.uk
  6. # Version: 110813
  7. #### Variables ####
  8. # Notification Email
  9. # (on|off)
  10. emailnotification="off"
  11. email="email@example.com"
  12. # Directorys
  13. rootdir="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
  14. selfname="$0"
  15. filesdir="${rootdir}/ut2k4"
  16. systemdir="${filesdir}/System"
  17. compressedmapsdir="${rootdir}/Maps-Compressed"
  18. # Server names
  19. servicename="ut2k4-server"
  20. gamename="Unreal Tournament 2004"
  21. ini="${servicename}.ini"
  22. servername=`grep -s ServerName= ${systemdir}/${ini} | sed 's/ServerName=//g'`
  23. # Logging
  24. logdir="${rootdir}/log"
  25. logfile="${logdir}/${servicename}.log"
  26. logfiledate="${logdir}/${servicename}-$( date '+%d-%m-%Y-%H-%M-%S').log"
  27. logdays="7"
  28. # Start vars
  29. defaultmap="DM-Rankin"
  30. parms="server ${defaultmap}?game=XGame.xDMGame -nohomedir ini=${ini} log=${logfile}"
  31. ##### Script #####
  32. # Do not edit
  33. # unless you know
  34. # what you are doing
  35. fn_rootcheck(){
  36. if [ `whoami` = "root" ];then
  37. echo -e "[\e[0;31m FAIL \e[0;39m] Script will not run as root!"
  38. exit
  39. fi
  40. }
  41. fn_syscheck(){
  42. if [ ! -e ${filesdir} ];then
  43. echo -e "[\e[0;31m FAIL \e[0;39m] Cannot access ${filesdir}: No such directory"
  44. exit
  45. fi
  46. }
  47. fn_runcheck(){
  48. # already running check
  49. pidwc=`screen -ls |grep ${servicename} |awk -F . '{print $1}'|awk '{print $1}'|wc -l`
  50. if [ ${pidwc} -eq 1 ];then
  51. echo -e "[\e[0;36m INFO \e[0;39m] ${servicename}: ${servername} is already running"
  52. echo -e "$( date '+%b %d %H:%M:%S') ${servicename}: ${servername} is already running" >> ${logfile}
  53. exit
  54. # multiple of same instance check
  55. elif [ ${pidwc} -ge 2 ];then
  56. echo -e "[\e[0;31m FAIL \e[0;39m] ${servicename}: ${servername} is running ${pidwc} times"
  57. echo -e "$( date '+%b %d %H:%M:%S') ${servicename}: ${servername} is running ${pidwc} times" >> ${logfile}
  58. echo -e "[\e[0;32m OK \e[0;39m] ${servicename}: Stopping ${pidwc} instances of ${servername}"
  59. echo -e "$( date '+%b %d %H:%M:%S') ${servicename}: Stopping ${pidwc} instances of ${servername}" >> ${logfile}
  60. fn_stopserver
  61. exit
  62. fi
  63. }
  64. fn_distro(){
  65. arch=$(uname -m)
  66. kernel=$(uname -r)
  67. if [ -f /etc/lsb-release ]; then
  68. os=$(lsb_release -s -d)
  69. elif [ -f /etc/debian_version ]; then
  70. os="Debian $(cat /etc/debian_version)"
  71. elif [ -f /etc/redhat-release ]; then
  72. os=`cat /etc/redhat-release`
  73. else
  74. os="$(uname -s) $(uname -r)"
  75. fi
  76. }
  77. fn_uptime(){
  78. uptime=$(</proc/uptime)
  79. uptime=${uptime%%.*}
  80. minutes=$(( uptime/60%60 ))
  81. hours=$(( uptime/60/60%24 ))
  82. days=$(( uptime/60/60/24 ))
  83. }
  84. fn_load(){
  85. load=$(uptime | awk -F 'load average' '{ print $2 }')
  86. }
  87. fn_emailnotification(){
  88. fn_distro
  89. fn_uptime
  90. fn_load
  91. {
  92. echo -e "=========================================\nServer information\n=========================================\n"
  93. echo -e "Date: $(date)"
  94. echo -e "Distro: ${os}"
  95. echo -e "Arch: ${arch}"
  96. echo -e "Kernel: ${kernel}"
  97. echo -e "Hostname: $HOSTNAME"
  98. echo -e "Uptime: ${days}d, ${hours}h, ${minutes}m"
  99. echo -e "Avg Load${load}\n"
  100. echo -e "=========================================\n${servicename} statistics\n=========================================\n"
  101. echo -e "Service: ${servicename}"
  102. echo -e "Server: ${servername}"
  103. echo -e "Failure reason: ${failurereason}"
  104. echo -e "Action Taken: ${actiontaken}\n"
  105. echo -e "=========================================\n${servicename} log summary\n=========================================\n"
  106. }|tee ${logdir}/${servicename}-email.log > /dev/null 2>&1
  107. tail -50 ${logfile} >> /${logdir}/${servicename}-email.log
  108. mail -s "${subject}" ${email} < /${logdir}/${servicename}-email.log
  109. echo -e "[\e[0;36m INFO \e[0;39m] Sent email notification to ${email}"
  110. echo -e "$( date '+%b %d %H:%M:%S') ${servicename}: sent email notification to ${email}" >> ${logfile}
  111. }
  112. fn_emailtest(){
  113. fn_rootcheck
  114. fn_syscheck
  115. echo -e "[\e[0;32m OK \e[0;39m] Emailing test notification"
  116. echo -e "$( date '+%b %d %H:%M:%S') ${servicename}: Emailing test notification" >> ${logfile}
  117. if [ "${emailnotification}" = "on" ];then
  118. subject="${servicename} Email Test Notification - Testing ${servername}"
  119. failurereason="Testing ${servicename} email notification"
  120. actiontaken="Sent test email...hello is this thing on?"
  121. fn_emailnotification
  122. else
  123. echo -e "[\e[0;31m FAIL \e[0;39m] Email notificaion not enabled"
  124. echo -e "$( date '+%b %d %H:%M:%S') ${servicename}: Email notificaion not enabled" >> ${logfile}
  125. fi
  126. }
  127. fn_logmanager(){
  128. # log manager will active if finds logs older than $logdays
  129. if [ `find ${logdir}/* -mtime +${logdays} |wc -l` -ne "0" ];then
  130. echo -e "[\e[0;32m OK \e[0;39m] Starting log cleaner"
  131. echo -e "$( date '+%b %d %H:%M:%S') ${servicename}: Starting log cleaner" >> ${logfile}
  132. echo -e "[\e[0;36m INFO \e[0;39m] Removing logs older than ${logdays} days"
  133. echo -e "$( date '+%b %d %H:%M:%S') ${servicename}: Removing logs older than ${logdays} days" >> ${logfile}
  134. find ${logdir}/* -mtime +${logdays} |tee >> ${logfile}
  135. count=`find ${logdir}/* -mtime +${logdays}|wc -l`
  136. find ${logdir}/* -mtime +${logdays} -exec rm {} \;
  137. echo -e "[\e[0;36m INFO \e[0;39m] Log cleaner removed ${count} log files"
  138. echo -e "$( date '+%b %d %H:%M:%S') ${servicename}: Log cleaner removed ${count} log files" >> ${logfile}
  139. fi
  140. }
  141. fn_restartserver(){
  142. echo -e "[\e[0;32m OK \e[0;39m] Restarting ${servicename}: ${servername}"
  143. echo -e "$( date '+%b %d %H:%M:%S') ${servicename}: Restarting ${servername}" >> ${logfile}
  144. fn_stopserver
  145. sleep 1
  146. fn_startserver
  147. }
  148. fn_startserver(){
  149. fn_rootcheck
  150. fn_syscheck
  151. fn_runcheck
  152. fn_logmanager
  153. cd ${systemdir}
  154. echo -e "[\e[0;32m OK \e[0;39m] Starting ${servicename}: ${servername}"
  155. echo -e "$( date '+%b %d %H:%M:%S') ${servicename}: Starting ${servername}" >> ${logfile}
  156. cp ${logfile} ${logfiledate}
  157. screen -d -m -S ${servicename} ./ucc-bin ${parms}
  158. sleep 1
  159. pidwc=`screen -ls |grep ${servicename} |awk -F . '{print $1}'|awk '{print $1}'|wc -l`
  160. if [ ${pidwc} -eq 0 ];then
  161. echo -e "[\e[0;31m FAIL \e[0;39m] ${servicename}: Failed to start ${servername}"
  162. echo -e "$( date '+%b %d %H:%M:%S') ${servicename}: failed to start ${servername}" >> ${logfile}
  163. fi
  164. }
  165. fn_stopserver(){
  166. fn_rootcheck
  167. fn_syscheck
  168. pid=`screen -ls |grep ${servicename} |awk -F . '{print $1}'|awk '{print $1}'`
  169. if [ -z ${pid} ];then
  170. echo -e "[\e[0;36m INFO \e[0;39m] ${servicename}: ${servername} is already stopped"
  171. echo -e "$( date '+%b %d %H:%M:%S') ${servicename}: ${servername} is already stopped" >> ${logfile}
  172. else
  173. echo -e "[\e[0;32m OK \e[0;39m] Stopping ${servicename}: ${servername}"
  174. echo -e "$( date '+%b %d %H:%M:%S') ${servicename}: Stopping ${servername}" >> ${logfile}
  175. kill `screen -ls |grep ${servicename} |awk -F . '{print $1}'|awk '{print $1}'`
  176. screen -wipe > /dev/null 2>&1
  177. fi
  178. }
  179. fn_debugserver(){
  180. fn_rootcheck
  181. fn_syscheck
  182. cd ${filesdir}
  183. echo -e "[\e[0;32m OK \e[0;39m] Starting ${servicename}: ${servername} in debug mode!"
  184. sleep 0.5
  185. echo -e ""
  186. echo -e "Use for identifying server issues only!"
  187. while true; do
  188. echo "If server is already running it will be stopped"
  189. read -p "Continue? [y/N]" yn
  190. case $yn in
  191. [Yy]* ) break;;
  192. [Nn]* ) echo Exiting; return 1 ;;
  193. * ) echo "Please answer yes or no.";;
  194. esac
  195. done
  196. fn_stopserver
  197. sleep 1
  198. echo -e "[\e[0;36m INFO \e[0;39m] Press CTRL+C to drop out of debug mode"
  199. sleep 3
  200. echo -e "[\e[0;32m OK \e[0;39m] Starting ${servicename}: ${servername}"
  201. cd ${systemdir}
  202. ./ucc-bin ${parms}
  203. }
  204. fn_monitorserver(){
  205. fn_rootcheck
  206. fn_syscheck
  207. fn_logmanager
  208. echo -e "[\e[0;32m OK \e[0;39m] Checking ${servicename}: ${servername}"
  209. echo -e "$( date '+%b %d %H:%M:%S') ${servicename}: Checking ${servername}" >> ${logfile}
  210. updatecheck=`ps -ef|grep "${selfname} update"|grep -v grep|wc -l`
  211. if [ "${updatecheck}" = "0" ];then
  212. fn_runcheck
  213. echo -e "[\e[1;33m WARN \e[0;39m] ${servicename}: Monitor detected ${servername} had stopped!"
  214. echo -e "$( date '+%b %d %H:%M:%S') ${servicename}: Monitor detected ${servername} had stopped!" >> ${logfile}
  215. if [ "${emailnotification}" = "on" ];then
  216. subject="${servicename} Monitor - Starting ${servername}"
  217. failurereason="${servername} had stopped"
  218. actiontaken="restarted ${servername}"
  219. fn_emailnotification
  220. fi
  221. fn_startserver
  222. else
  223. echo -e "[\e[0;36m INFO \e[0;39m] ${servicename}: Monitor detected ${servername} is currently checking for updates!"
  224. echo -e "$( date '+%b %d %H:%M:%S') ${servicename}: Monitor detected ${servername} is currently checking for updates!" >> ${logfile}
  225. echo -e "[\e[0;36m INFO \e[0;39m] ${servicename}: ${servername} will start when updating is complete"
  226. echo -e "$( date '+%b %d %H:%M:%S') ${servicename}: ${servername} will start when updating is complete" >> ${logfile}
  227. fi
  228. }
  229. fn_compressmaps(){
  230. fn_rootcheck
  231. clear
  232. echo "${gamename} Map Compressor"
  233. echo "============================"
  234. echo "Will compress all maps in:"
  235. echo ""
  236. pwd
  237. echo ""
  238. echo "Compressed maps saved to:"
  239. echo ""
  240. echo "$compressedmapsdir"
  241. echo ""
  242. while true; do
  243. read -p "Start compression [y/N]" yn
  244. case $yn in
  245. [Yy]* ) break;;
  246. [Nn]* ) echo Exiting; return 1 ;;
  247. * ) echo "Please answer yes or no.";;
  248. esac
  249. done
  250. mkdir $compressedmapsdir
  251. rm -rfv ${filesdir}/Maps/*.uz2
  252. cd ${systemdir}
  253. ./ucc-bin compress ../Maps/* --nohomedir
  254. mv -fv ${filesdir}/Maps/*.uz2 $compressedmapsdir
  255. }
  256. #
  257. ##Installer
  258. #
  259. fn_header(){
  260. clear
  261. echo "================================="
  262. echo "${gamename}"
  263. echo "Server Linux Installer"
  264. echo "by Daniel Gibbs"
  265. echo "http://danielgibbs.co.uk"
  266. echo "================================="
  267. echo ""
  268. }
  269. fn_filesdl(){
  270. echo ""
  271. echo "Downloading Server Files"
  272. echo "============================"
  273. cd ${rootdir}
  274. mkdir ${filesdir}
  275. cd ${filesdir}
  276. if [ ! -f dedicatedserver3339-bonuspack.zip ];then
  277. wget http://downloads.unrealadmin.org/UT2004/Server/dedicatedserver3339-bonuspack.zip
  278. else
  279. echo "dedicatedserver3339-bonuspack.zip already downloaded!"
  280. fi
  281. echo "Running MD5 checksum to verify the file"
  282. sleep 1
  283. echo "MD5 checksum: d3f28c5245c4c02802d48e4f0ffd3e34"
  284. md5check=`md5sum dedicatedserver3339-bonuspack.zip| awk '{print $1;}'`
  285. echo "File returned: ${md5check}"
  286. if [ "${md5check}" != "d3f28c5245c4c02802d48e4f0ffd3e34" ];then
  287. echo "MD5 checksum: FAILED!"
  288. read -p "Retry download? [y/N]" yn
  289. case $yn in
  290. [Yy]* ) rm -f dedicatedserver3339-bonuspack.zip; fn_filesdl;;
  291. [Nn]* ) echo Exiting; exit ;;
  292. * ) echo "Please answer yes or no.";;
  293. esac
  294. else
  295. echo "MD5 checksum: PASSED"
  296. fi
  297. }
  298. fn_retryinstall(){
  299. while true; do
  300. read -p "Retry install? [y/N]" yn
  301. case $yn in
  302. [Yy]* ) fn_install;;
  303. [Nn]* ) echo Exiting; exit ;;
  304. * ) echo "Please answer yes or no.";;
  305. esac
  306. done
  307. }
  308. fn_install(){
  309. fn_rootcheck
  310. fn_header
  311. if [ -d ${filesdir} ];then
  312. echo "${gamename} Server is already installed here:"
  313. pwd
  314. echo ""
  315. while true; do
  316. read -p "Continue [y/N]" yn
  317. case $yn in
  318. [Yy]* ) break;;
  319. [Nn]* ) echo Exiting; return 1 ;;
  320. * ) echo "Please answer yes or no.";;
  321. esac
  322. done
  323. fi
  324. fn_header
  325. echo "Install Directory:"
  326. pwd
  327. echo ""
  328. while true; do
  329. read -p "Continue [y/N]" yn
  330. case $yn in
  331. [Yy]* ) break;;
  332. [Nn]* ) echo Exiting; return 1 ;;
  333. * ) echo "Please answer yes or no.";;
  334. esac
  335. done
  336. fn_header
  337. fn_filesdl
  338. echo ""
  339. echo "Installing ${gamename} Server"
  340. echo "================================="
  341. cd ${filesdir}
  342. unzip dedicatedserver3339-bonuspack.zip
  343. cd ${systemdir}
  344. chmod +x ucc-bin
  345. while true; do
  346. read -p "Was the install successful? [y/N]" yn
  347. case $yn in
  348. [Yy]* ) break;;
  349. [Nn]* ) fn_retryinstall ;;
  350. * ) echo "Please answer yes or no.";;
  351. esac
  352. done
  353. cd ${filesdir}
  354. while true; do
  355. read -p "Remove dedicatedserver3339-bonuspack.zip? [y/N]" yn
  356. case $yn in
  357. [Yy]* ) rm -iv dedicatedserver3339-bonuspack.zip ; break ;;
  358. [Nn]* ) break ;;
  359. * ) echo "Please answer yes or no.";;
  360. esac
  361. done
  362. echo ""
  363. echo "Configuring ${gamename} Server"
  364. echo "================================="
  365. echo "Copying ${systemdir}/ut2004.ini to ${systemdir}/${ini}"
  366. cp ${systemdir}/UT2004.ini ${systemdir}/${ini}
  367. sleep 1
  368. echo ""
  369. echo "Applying WebAdmin CharSet fix!"
  370. echo "http://forums.tripwireinteractive.com/showpost.php?p=442340&postcount=1"
  371. sleep 1
  372. echo ""
  373. echo "Applying WebAdmin ut2003.css fix!"
  374. echo "http://forums.tripwireinteractive.com/showpost.php?p=585435&postcount=13"
  375. sleep 1
  376. echo ""
  377. echo "Setting WebAdmin port to 8077"
  378. sleep 1
  379. echo ""
  380. echo "Setting WebAdmin username and password"
  381. sleep 1
  382. echo ""
  383. echo "Enabling Web Interface"
  384. sleep 2
  385. sed -i 's/CharSet="iso-8859-1"/CharSet="utf-8"/g' ${systemdir}/UWeb.int
  386. sed -i 's/none}/none;/g' ${filesdir}/Web/ServerAdmin/ut2003.css
  387. sed -i 's/underline}/underline;/g' ${filesdir}/Web/ServerAdmin/ut2003.css
  388. sed -i 's/AdminName=/AdminName=admin/g' ${systemdir}/${ini}
  389. sed -i 's/AdminPassword=/AdminPassword=utpass/g' ${systemdir}/${ini}
  390. sed -i 's/bEnabled=False/bEnabled=True/g' ${systemdir}/${ini}
  391. sed -i 's/ListenPort=80/ListenPort=8077/g' ${systemdir}/${ini}
  392. mkdir ${logdir}
  393. cd ${rootdir}
  394. echo ""
  395. echo "Default Settings"
  396. echo "=============================="
  397. echo "WebAdmin Details:"
  398. echo "Url: http://localhost:8077"
  399. echo "Username: admin"
  400. echo "Password: utpass"
  401. echo ""
  402. echo "Port Details:"
  403. echo "8077 TCP (WebAdmin Port)"
  404. echo "7777 UDP (Game Port)"
  405. echo "7778 UDP (Query Port)"
  406. echo "7787 UDP (GameSpy Query Port)"
  407. echo "28902 TCP & UDP (Allows your Server to Connect to the Master Server Browser)"
  408. echo "20560 UDP (Steam Port)"
  409. echo "================================="
  410. echo "Install Complete!"
  411. echo ""
  412. echo "To start server type:"
  413. echo "${selfname} start"
  414. }
  415. case "$1" in
  416. start)
  417. fn_startserver;;
  418. stop)
  419. fn_stopserver;;
  420. restart)
  421. fn_restartserver;;
  422. monitor)
  423. fn_monitorserver;;
  424. install)
  425. fn_install;;
  426. debug)
  427. fn_debugserver;;
  428. map-compressor)
  429. fn_compressmaps;;
  430. email-test)
  431. fn_emailtest;;
  432. *)
  433. echo "Usage: $0 {start|stop|restart|monitor|install|debug|map-compressor|email-test}"
  434. exit 1;;
  435. esac
  436. exit