@ -1,652 +1,137 @@
#!/bin/bash
# LGSM command_details.sh function
# Author: Daniel Gibbs
# Contributor: UltimateByte
#!/bin/bash -x
# LGSM command_post details.sh function
# Author: CedarLUG
# Contributor: CedarLUG
# Website: https://gameservermanagers.com
# Description: Displays server information.
# Description: Strips sensitive information out of Details output
local commandname = "DETAILS"
local commandaction = "D etails"
local commandname = "POST DETAILS"
local commandaction = "Postd etails"
local function_selfname = " $( basename $( readlink -f " ${ BASH_SOURCE [0] } " ) ) "
# Standard Details
# This applies to all engines
# POSTDETAILS variable affects the output of command_details.sh. Setting
# it here silences the output from sourcing command_details.sh.
POSTDETAILS = yes
fn_details_os( ) {
# Set POSTTARGET to the appropriately-defined post destination. The present
# option is only pastebin, but hastebin is on the todo list (and should be
# a lot easier than pastebin.
#
# Distro Details
# =====================================
# Distro: Ubuntu 14.04.4 LTS
# Arch: x86_64
# Kernel: 3.13.0-79-generic
# Hostname: hostname
# tmux: tmux 1.8
# GLIBC: 2.19
# Another reason for an alternative here is that pastebin limits guest
# posts to 10 per day, which might be a tight limit for some debugging situations.
echo -e ""
echo -e " ${ lightyellow } Distro Details ${ default } "
printf '%*s\n' " ${ COLUMNS :- $( tput cols) } " '' | tr ' ' =
{
echo -e " ${ blue } Distro:\t ${ default } ${ distroname } "
echo -e " ${ blue } Arch:\t ${ default } ${ arch } "
echo -e " ${ blue } Kernel:\t ${ default } ${ kernel } "
echo -e " ${ blue } Hostname:\t ${ default } $HOSTNAME "
echo -e " ${ blue } tmux:\t ${ default } ${ tmuxv } "
echo -e " ${ blue } GLIBC:\t ${ default } ${ glibcversion } "
} | column -s $'\t' -t
}
fn_details_performance( ) {
#
# Performance
# =====================================
# Uptime: 55d, 3h, 38m
# Avg Load: 1.00, 1.01, 0.78
#
# Mem: total used free cached
# Physical: 741M 656M 85M 256M
# Swap: 0B 0B 0B
echo -e ""
echo -e " ${ lightyellow } Performance ${ default } "
printf '%*s\n' " ${ COLUMNS :- $( tput cols) } " '' | tr ' ' =
{
echo -e " ${ blue } Uptime:\t ${ default } ${ days } d, ${ hours } h, ${ minutes } m "
echo -e " ${ blue } Avg Load:\t ${ default } ${ load } "
} | column -s $'\t' -t
echo -e ""
{
echo -e " ${ blue } Mem:\t ${ blue } total\t used\t free\t cached ${ default } "
echo -e " ${ blue } Physical:\t ${ default } ${ physmemtotal } \t ${ physmemused } \t ${ physmemfree } \t ${ physmemcached } ${ default } "
echo -e " ${ blue } Swap:\t ${ default } ${ swaptotal } \t ${ swapused } \t ${ swapfree } ${ default } "
} | column -s $'\t' -t
}
fn_details_disk( ) {
#
# Storage
# =====================================
# Filesystem: /dev/disk/by-uuid/320c8edd-a2ce-4a23-8c9d-e00a7af2d6ff
# Total: 15G
# Used: 8.4G
# Available: 5.7G
# LGSM Total: 1G
# Serverfiles: 961M
# Backups: 2G
echo -e ""
echo -e " ${ lightyellow } Storage ${ default } "
printf '%*s\n' " ${ COLUMNS :- $( tput cols) } " '' | tr ' ' =
{
echo -e " ${ blue } Filesystem:\t ${ default } ${ filesystem } "
echo -e " ${ blue } Total:\t ${ default } ${ totalspace } "
echo -e " ${ blue } Used:\t ${ default } ${ usedspace } "
echo -e " ${ blue } Available:\t ${ default } ${ availspace } "
echo -e " ${ blue } LGSM Total:\t ${ default } ${ rootdirdu } "
echo -e " ${ blue } Serverfiles:\t ${ default } ${ filesdirdu } "
if [ -d " ${ backupdir } " ] ; then
echo -e " ${ blue } Backups:\t ${ default } ${ backupdirdu } "
fi
} | column -s $'\t' -t
}
fn_details_gameserver( ) {
#
# Quake Live Server Details
# =====================================
# Server name: ql-server
# Server IP: 1.2.3.4:27960
# RCON password: CHANGE_ME
# Server password: NOT SET
# Slots: 16
# Status: OFFLINE
echo -e ""
echo -e " ${ lightgreen } ${ gamename } Server Details ${ default } "
printf '%*s\n' " ${ COLUMNS :- $( tput cols) } " '' | tr ' ' =
{
# Server name
if [ -n " ${ servername } " ] ; then
echo -e " ${ blue } Server name:\t ${ default } ${ servername } "
fi
# Server ip
echo -e " ${ blue } Server IP:\t ${ default } ${ ip } : ${ port } "
#POSTTARGET="http://pastebin.com"
POSTTARGET = "http://hastebin.com"
POSTEXPIRE = "1W" # use 1 week as the default, other options are '24h' for a day, etc.
# Server password
if [ -n " ${ serverpassword } " ] ; then
echo -e " ${ blue } Server password:\t ${ default } ${ serverpassword } "
fi
# RCON password
if [ -n " ${ rconpassword } " ] ; then
echo -e " ${ blue } RCON password:\t ${ default } ${ rconpassword } "
fi
# Admin password
if [ -n " ${ adminpassword } " ] ; then
echo -e " ${ blue } Admin password:\t ${ default } ${ adminpassword } "
fi
# Stats password (Quake Live)
if [ -n " ${ statspassword } " ] ; then
echo -e " ${ blue } Stats password:\t ${ default } ${ statspassword } "
fi
# Slots
if [ -n " ${ slots } " ] ; then
echo -e " ${ blue } Slots:\t ${ default } ${ slots } "
fi
# Game mode
if [ -n " ${ gamemode } " ] ; then
echo -e " ${ blue } Game mode:\t ${ default } ${ gamemode } "
fi
# Game world
if [ -n " ${ gameworld } " ] ; then
echo -e " ${ blue } Game world:\t ${ default } ${ gameworld } "
fi
# Tick rate
if [ -n " ${ tickrate } " ] ; then
echo -e " ${ blue } Tick rate:\t ${ default } ${ tickrate } "
fi
# This file sources the command_details.sh file to leverage all
# of the already-defined functions. To keep the command_details.sh
# from actually producing output, the main executable statements have
# been wrapped in the equivalent of an ifdef clause, that looks
# for the variable "postdetails" to be defined. -CedarLUG
# TeamSpeak dbplugin
if [ -n " ${ dbplugin } " ] ; then
echo -e " ${ blue } dbplugin:\t ${ default } ${ dbplugin } "
fi
# source all of the functions defined in the details command
. ${ functionsdir } /command_details.sh
# Online status
if [ " ${ status } " = = "0" ] ; then
echo -e " ${ blue } Status:\t ${ red } OFFLINE ${ default } "
else
echo -e " ${ blue } Status:\t ${ green } ONLINE ${ default } "
fi
} | column -s $'\t' -t
echo -e ""
fn_bad_tmpfile( ) {
echo " There was a problem creating a temporary file ${ tmpfile } . "
core_exit.sh
}
fn_details_script( ) {
fn_gen_rand( ) {
# This is just a simple random generator to generate a random
# name for storing the output. Named pipes would (possibly) be
# better. -CedarLUG
#
# qlserver Script Details
# =====================================
# Service name: ql-server
# qlserver version: 150316
# User: lgsm
# Email alert: off
# Update on start: off
# Location: /home/lgsm/qlserver
# Config file: /home/lgsm/qlserver/serverfiles/baseq3/ql-server.cfg
echo -e " ${ lightgreen } ${ selfname } Script Details ${ default } "
printf '%*s\n' " ${ COLUMNS :- $( tput cols) } " '' | tr ' ' =
{
# Service name
echo -e " ${ blue } Service name:\t ${ default } ${ servicename } "
# Script version
if [ -n " ${ version } " ] ; then
echo -e " ${ blue } ${ selfname } version:\t ${ default } ${ version } "
fi
# User
echo -e " ${ blue } User:\t ${ default } $( whoami) "
# GLIBC required
if [ -n " ${ glibcrequired } " ] ; then
if [ " ${ glibcrequired } " = = "NOT REQUIRED" ] ; then
:
elif [ " ${ glibcrequired } " = = "UNKNOWN" ] ; then
echo -e " ${ blue } GLIBC required:\t ${ red } ${ glibcrequired } "
elif [ " $( printf '%s\n' ${ glibcrequired } '\n' ${ glibcversion } | sort -V | head -n 1) " != " ${ glibcrequired } " ] ; then
if [ " ${ glibcfix } " = = "yes" ] ; then
echo -e " ${ blue } GLIBC required:\t ${ red } ${ glibcrequired } ${ default } ( ${ green } Using GLIBC fix ${ default } ) "
else
echo -e " ${ blue } GLIBC required:\t ${ red } ${ glibcrequired } ${ default } ( ${ red } GLIBC version too old ${ default } ) "
fi
else
echo -e " ${ blue } GLIBC required:\t ${ green } ${ glibcrequired } ${ default } "
fi
fi
# Email alert
echo -e " ${ blue } Email alert:\t ${ default } ${ emailalert } "
# Pushbullet alert
echo -e " ${ blue } Pushbullet alert:\t ${ default } ${ pushbulletalert } "
# Update on start
echo -e " ${ blue } Update on start:\t ${ default } ${ updateonstart } "
# Script location
echo -e " ${ blue } Location:\t ${ default } ${ rootdir } "
# Config file location
if [ -n " ${ servercfgfullpath } " ] ; then
if [ -f " ${ servercfgfullpath } " ] ; then
echo -e " ${ blue } Config file:\t ${ default } ${ servercfgfullpath } "
else
echo -e " ${ blue } Config file:\t ${ default } ${ red } ${ servercfgfullpath } ${ default } ( ${ red } FILE MISSING ${ default } ) "
fi
fi
# Network config file location (ARMA 3)
if [ -n " ${ networkcfgfullpath } " ] ; then
echo -e " ${ blue } Network config file:\t ${ default } ${ networkcfgfullpath } "
fi
} | column -s $'\t' -t
}
fn_details_backup( ) {
# len holds the number of digits in our random string
local len = $1
# If not specified, default to 10.
: { len:= 10}
# Quick generator for a random filename, pulled from /dev/urandom
tr -dc A-Za-z0-9_ < /dev/urandom | head -c ${ len } | xargs
}
# Rather than a one-pass sed parser, default to using a temporary directory
filedir = " ${ lgsmdir } /tmp "
# Not all game servers possess a tmp directory. So create it if
# it doesn't already exist
mkdir -p ${ filedir } 2>& 1 >/dev/null
tmpfile = ${ filedir } /$( fn_gen_rand 10) .tmp
touch ${ tmpfile } || fn_bad_tmpfile
# fn_display_details is found in the command_details.sh file (which
# was sourced above. The output is parsed for passwords and other
# confidential information. -CedarLUG
# The numerous sed lines could certainly be condensed quite a bit,
# but they are separated out to provide examples for how to add
# additional criteria in a straight-forward manner.
# (This was originally a sed one-liner.) -CedarLUG
fn_display_details | sed -e 's/password="[^"]*/password="--stripped--/' |
sed -e 's/password "[^"]*/password "--stripped--/' |
sed -e 's/password: .*/password: --stripped--/' |
sed -e 's/gslt="[^"]*/gslt="--stripped--/' |
sed -e 's/gslt "[^"]*/gslt "--stripped--/' |
sed -e 's/pushbullettoken="[^"]*/pushbullettoken="--stripped--/' |
sed -e 's/pushbullettoken "[^"]*/pushbullettoken "--stripped--/' |
sed -e 's/authkey="[^"]*/authkey="--stripped--/' |
sed -e 's/authkey "[^"]*/authkey "--stripped--/' |
sed -e 's/authkey [A-Za-z0-9]\+/authkey --stripped--/' |
sed -e 's/rcts_strAdminPassword="[^"]*/rcts_strAdminPassword="--stripped--/' |
sed -e 's/rcts_strAdminPassword "[^"]*/rcts_strAdminPassword "--stripped--/' |
sed -e 's/sv_setsteamaccount [A-Za-z0-9]\+/sv_setsteamaccount --stripped--/' |
sed -e 's/sv_password="[^"]*/sv_password="--stripped--/' |
sed -e 's/sv_password "[^"]*/sv_password "--stripped--/' |
sed -e 's/zmq_stats_password="[^"]*/zmq_stats_password="--stripped--/' |
sed -e 's/zmq_stats_password "[^"]*/zmq_stats_password "--stripped--/' |
sed -e 's/zmq_rcon_password="[^"]*/zmq_rcon_password="--stripped--/' |
sed -e 's/zmq_rcon_password "[^"]*/zmq_rcon_password "--stripped--/' |
sed -e 's/pass="[^"]*/pass="--stripped--/' |
sed -e 's/pass "[^"]*/pass "--stripped--/' |
sed -e 's/rconServerPassword="[^"]*/rconServerPassword="--stripped--/' |
sed -e 's/rconServerPassword "[^"]*/rconServerPassword "--stripped--/' > ${ tmpfile }
# strip off all console escape codes (colorization)
sed -i -r "s/[\x1B,\x0B]\[([0-9]{1,2}(;[0-9]{1,2})?)?[mGK]//g" ${ tmpfile }
# If the gameserver uses anonymous steam credentials, leave them displayed
# in the output. Otherwise, strip these out as well.
if ! grep -q "^steampass[= ]\"\"" ${ tmpfile } ; then
sed -i -e 's/steampass[= ]"[^"]*/steampass "--stripped--/' ${ tmpfile }
fi
if ! grep -q "^steamuser[= ]\"anonymous\"" ${ tmpfile } ; then
sed -i -e 's/steamuser[= ]"[^"]*/steamuser "--stripped--/' ${ tmpfile }
fi
if [ " $POSTTARGET " = = "http://pastebin.com" ] ; then
# grab the return from 'value' from an initial visit to pastebin.
TOKEN = $( curl -s $POSTTARGET |
sed -n 's/^.*input type="hidden" name="csrf_token_post" value="\(.*\)".*$/\1/p' )
#
# Backups
# =====================================
# No. of backups: 1
# Latest backup:
# date: Fri May 6 18:34:19 UTC 2016
# file: /home/lgsm/qlserver/backups/ql-server-2016-05-06-183239.tar.gz
# size: 945M
echo -e ""
echo -e " ${ lightgreen } Backups ${ default } "
printf '%*s\n' " ${ COLUMNS :- $( tput cols) } " '' | tr ' ' =
if [ ! -d " ${ backupdir } " ] || [ " ${ backupcount } " = = "0" ] ; then
echo -e "No Backups created"
else
{
echo -e " ${ blue } No. of backups:\t ${ default } ${ backupcount } "
echo -e " ${ blue } Latest backup: ${ default } "
echo -e " ${ blue } date:\t ${ default } ${ lastbackupdate } "
echo -e " ${ blue } file:\t ${ default } ${ lastbackup } "
echo -e " ${ blue } size:\t ${ default } ${ lastbackupsize } "
} | column -s $'\t' -t
fi
}
fn_details_commandlineparms( ) {
# Use the TOKEN to then post the content.
#
# Command-line Parameters
# =====================================
# ./run_server_x86.sh +set net_strict 1
echo -e ""
echo -e " ${ lightgreen } Command-line Parameters ${ default } "
printf '%*s\n' " ${ COLUMNS :- $( tput cols) } " '' | tr ' ' =
echo -e " ${ executable } ${ parms } "
}
fn_details_ports( ) {
# Ports
# =====================================
# Change ports by editing the parameters in:
# /home/lgsm/qlserver/serverfiles/baseq3/ql-server.cfg
link = $( curl -s " $POSTTARGET /post.php " -D - -F "submit_hidden=submit_hidden" \
-F " post_key= $TOKEN " -F " paste_expire_date= ${ POSTEXPIRE } " \
-F " paste_name= ${ gamename } Debug Info " \
-F "paste_format=8" -F "paste_private=0" \
-F "paste_type=bash" -F " paste_code=< ${ tmpfile } " |
awk '/^location: / { print $2 }' | sed "s/\n//g" )
# Output the resulting link.
fn_print_warn_nl " You now need to visit (and verify) the content posted at ${ POSTTARGET } ${ link } "
elif [ " $POSTTARGET " = = "http://hastebin.com" ] ; then
# hastebin is a bit simpler. If successful, the returned result
# should look like: {"something":"key"}, putting the reference that
# we need in "key". TODO - error handling. -CedarLUG
link = $( curl -s -d " $( <${ tmpfile } ) " ${ POSTTARGET } /documents| cut -d\" -f4)
fn_print_warn_nl " You now need to visit (and verify) the content posted at ${ POSTTARGET } / ${ link } "
fi
# cleanup
rm ${ tmpfile } || /bin/true
echo -e ""
echo -e " ${ lightgreen } Ports ${ default } "
printf '%*s\n' " ${ COLUMNS :- $( tput cols) } " '' | tr ' ' =
echo -e "Change ports by editing the parameters in:"
parmslocation = " ${ red } UNKNOWN ${ default } "
# engines that require editing in the config file
local ports_edit_array = ( "avalanche" "dontstarve" "idtech3" "lwjgl2" "projectzomboid" "realvirtuality" "seriousengine35" "teeworlds" "terraria" "unreal" "unreal2" "TeamSpeak 3" "Mumble" "7 Days To Die" )
for port_edit in " ${ ports_edit_array [@] } "
do
if [ " ${ engine } " = = " ${ port_edit } " ] || [ " ${ gamename } " = = " ${ port_edit } " ] ; then
parmslocation = " ${ servercfgfullpath } "
fi
done
# engines that require editing in the script file
local ports_edit_array = ( "starbound" "spark" "source" "goldsource" "Rust" "Hurtworld" "unreal4" )
for port_edit in " ${ ports_edit_array [@] } "
do
if [ " ${ engine } " = = " ${ port_edit } " ] || [ " ${ gamename } " = = " ${ port_edit } " ] ; then
parmslocation = " ${ selfname } "
fi
done
echo -e " ${ parmslocation } "
echo -e ""
echo -e "Useful port diagnostic command:"
}
fn_details_statusbottom( ) {
echo -e ""
if [ " ${ status } " = = "0" ] ; then
echo -e " ${ blue } Status:\t ${ red } OFFLINE ${ default } "
else
echo -e " ${ blue } Status:\t ${ green } ONLINE ${ default } "
fi
echo -e ""
}
# Engine Specific details
fn_details_avalanche( ) {
echo -e "netstat -atunp | grep Jcmp-Server"
echo -e ""
{
echo -e "DESCRIPTION\tDIRECTION\tPORT\tPROTOCOL"
echo -e " > Game\tINBOUND\t ${ port } \tudp "
} | column -s $'\t' -t
}
fn_details_dontstarve( ) {
echo -e "netstat -atunp | grep dontstarve"
echo -e ""
{
echo -e "DESCRIPTION\tDIRECTION\tPORT\tPROTOCOL"
echo -e " > Game\tINBOUND\t ${ port } \tudp "
} | column -s $'\t' -t
}
fn_details_minecraft( ) {
echo -e "netstat -atunp | grep java"
echo -e ""
{
echo -e "DESCRIPTION\tDIRECTION\tPORT\tPROTOCOL"
echo -e " > Game\tINBOUND\t ${ port } \tudp "
} | column -s $'\t' -t
}
fn_details_projectzomboid( ) {
echo -e "netstat -atunp | grep java"
echo -e ""
{
echo -e "DESCRIPTION\tDIRECTION\tPORT\tPROTOCOL"
echo -e " > Game\tINBOUND\t ${ port } \tudp "
} | column -s $'\t' -t
}
fn_details_realvirtuality( ) {
echo -e "netstat -atunp | grep arma3server"
echo -e ""
if [ -z " ${ port } " ] || [ -z " ${ queryport } " ] || [ -z " ${ masterport } " ] ; then
echo -e " ${ red } ERROR! ${ default } Missing/commented ports in ${ servercfg } . "
echo -e ""
fi
{
echo -e "DESCRIPTION\tDIRECTION\tPORT\tPROTOCOL"
echo -e " > Game\tINBOUND\t ${ port } \tudp "
echo -e " > Steam: Query\tINBOUND\t ${ queryport } \tudp "
echo -e " > Steam: Master traffic\tINBOUND\t ${ masterport } \tudp "
} | column -s $'\t' -t
}
fn_details_idtech3( ) {
echo -e "netstat -atunp | grep qzeroded"
echo -e ""
if [ -z " ${ port } " ] || [ -z " ${ rconport } " ] || [ -z " ${ statsport } " ] ; then
echo -e " ${ red } ERROR! ${ default } Missing/commented ports in ${ servercfg } . "
echo -e ""
fi
{
echo -e "DESCRIPTION\tDIRECTION\tPORT\tPROTOCOL"
echo -e " > Game\tINBOUND\t ${ port } \tudp "
echo -e " > Rcon\tINBOUND\t ${ rconport } \tudp "
echo -e " > Stats\tINBOUND\t ${ statsport } \tudp "
} | column -s $'\t' -t
}
fn_details_seriousengine35( ) {
echo -e "netstat -atunp | grep Sam3_Dedicate"
echo -e ""
{
echo -e "DESCRIPTION\tDIRECTION\tPORT\tPROTOCOL"
echo -e " > Game/RCON\tINBOUND\t ${ port } \ttcp "
echo -e " > Query\tINBOUND\t ${ queryport } \tudp "
} | column -s $'\t' -t
}
fn_details_source( ) {
echo -e "netstat -atunp | grep srcds_linux"
echo -e ""
{
echo -e "DESCRIPTION\tDIRECTION\tPORT\tPROTOCOL"
echo -e " > Game/RCON\tINBOUND\t ${ port } \ttcp/udp "
if [ -n " ${ sourcetvport } " ] ; then
echo -e " > SourceTV\tINBOUND\t ${ sourcetvport } \tudp "
fi
echo -e " < Client\tOUTBOUND\t ${ clientport } \tudp "
} | column -s $'\t' -t
}
fn_details_spark( ) {
echo -e "netstat -atunp | grep server_linux3"
echo -e ""
{
echo -e "DESCRIPTION\tDIRECTION\tPORT\tPROTOCOL"
echo -e " > Game/RCON\tINBOUND\t ${ port } \tudp "
echo -e " > Query\tINBOUND\t ${ queryport } \tudp "
echo -e " > WebAdmin\tINBOUND\t ${ webadminport } \ttcp "
} | column -s $'\t' -t
echo -e ""
echo -e " ${ lightgreen } ${ servername } WebAdmin ${ default } "
printf '%*s\n' " ${ COLUMNS :- $( tput cols) } " '' | tr ' ' =
{
echo -e " ${ blue } WebAdmin url:\t ${ default } http:// ${ ip } : ${ webadminport } /index.html "
echo -e " ${ blue } WebAdmin username:\t ${ default } ${ webadminuser } "
echo -e " ${ blue } WebAdmin password:\t ${ default } ${ webadminpass } "
} | column -s $'\t' -t
}
fn_details_starbound( ) {
echo -e "netstat -atunp | grep starbound"
echo -e ""
{
echo -e "DESCRIPTION\tDIRECTION\tPORT\tPROTOCOL"
echo -e " > Game\tINBOUND\t ${ port } \ttcp "
echo -e " > Query\tINBOUND\t ${ queryport } \ttcp "
echo -e " > Rcon\tINBOUND\t ${ rconport } \ttcp "
} | column -s $'\t' -t
}
fn_details_teamspeak3( ) {
echo -e "netstat -atunp | grep ts3server"
echo -e ""
{
echo -e "DESCRIPTION\tDIRECTION\tPORT\tPROTOCOL"
echo -e " > Voice\tINBOUND\t ${ port } \tudp "
echo -e " > ServerQuery\tINBOUND\t ${ queryport } \ttcp "
echo -e " > File transfer\tINBOUND\t ${ fileport } \ttcp "
} | column -s $'\t' -t
}
fn_details_mumble( ) {
echo -e "netstat -atunp | grep murmur"
echo -e ""
{
echo -e "DESCRIPTION\tDIRECTION\tPORT\tPROTOCOL"
echo -e " > Voice\tINBOUND\t ${ port } \tudp "
echo -e " > ServerQuery\tINBOUND\t ${ port } \ttcp "
} | column -s $'\t' -t
}
fn_details_teeworlds( ) {
echo -e "netstat -atunp | grep teeworlds_srv"
echo -e ""
{
echo -e "DESCRIPTION\tDIRECTION\tPORT\tPROTOCOL"
echo -e " > Game\tINBOUND\t ${ port } \ttcp "
} | column -s $'\t' -t
}
fn_details_terraria( ) {
echo -e "netstat -atunp | grep TerrariaServer"
echo -e ""
{
echo -e "DESCRIPTION\tDIRECTION\tPORT\tPROTOCOL"
echo -e " > Game\tINBOUND\t ${ port } \ttcp "
} | column -s $'\t' -t
}
fn_details_sdtd( ) {
echo -e "netstat -atunp | grep 7DaysToDie"
echo -e ""
{
echo -e "DESCRIPTION\tDIRECTION\tPORT\tPROTOCOL"
echo -e " > Game/RCON\tINBOUND\t ${ port } \tudp "
echo -e " > Query\tINBOUND\t ${ queryport } \tudp "
echo -e " > WebAdmin\tINBOUND\t ${ webadminport } \ttcp "
echo -e " > Telnet\tINBOUND\t ${ telnetport } \ttcp "
} | column -s $'\t' -t
echo -e ""
echo -e " ${ lightgreen } ${ servername } WebAdmin ${ default } "
printf '%*s\n' " ${ COLUMNS :- $( tput cols) } " '' | tr ' ' =
{
echo -e " ${ blue } WebAdmin enabled:\t ${ default } ${ webadminenabled } "
echo -e " ${ blue } WebAdmin url:\t ${ default } http:// ${ ip } : ${ webadminport } "
echo -e " ${ blue } WebAdmin password:\t ${ default } ${ webadminpass } "
} | column -s $'\t' -t
echo -e ""
echo -e " ${ lightgreen } ${ servername } Telnet ${ default } "
printf '%*s\n' " ${ COLUMNS :- $( tput cols) } " '' | tr ' ' =
{
echo -e " ${ blue } Telnet enabled:\t ${ default } ${ telnetenabled } "
echo -e " ${ blue } Telnet address:\t ${ default } ${ ip } ${ telnetport } "
echo -e " ${ blue } Telnet password:\t ${ default } ${ telnetpass } "
} | column -s $'\t' -t
}
fn_details_hurtworld( ) {
echo -e "netstat -atunp | grep Hurtworld"
echo -e ""
{
echo -e "DESCRIPTION\tDIRECTION\tPORT\tPROTOCOL"
echo -e " > Game/RCON\tINBOUND\t ${ port } \tudp "
echo -e " > Query\tINBOUND\t ${ queryport } \tudp "
} | column -s $'\t' -t
}
fn_details_rust( ) {
echo -e "netstat -atunp | grep Rust"
echo -e ""
{
echo -e "DESCRIPTION\tDIRECTION\tPORT\tPROTOCOL"
echo -e " > Game/Query\tINBOUND\t ${ port } \ttcp/udp "
echo -e " > RCON\tINBOUND\t ${ rconport } \ttcp "
} | column -s $'\t' -t
}
fn_details_unreal( ) {
echo -e "netstat -atunp | grep ucc-bin"
echo -e ""
{
echo -e "DESCRIPTION\tDIRECTION\tPORT\tPROTOCOL\tINI VARIABLE"
echo -e " > Game\tINBOUND\t ${ port } \tudp\tPort= ${ port } "
echo -e " > Query\tINBOUND\t ${ queryport } \tudp "
if [ " ${ engine } " = = "unreal" ] ; then
echo -e " < UdpLink Port (random)\tOUTBOUND\t ${ udplinkport } +\tudp "
fi
if [ " ${ engine } " != "unreal" ] && [ " ${ appid } " != "223250" ] ; then
echo -e " > GameSpy query\tINBOUND\t ${ gsqueryport } \tudp\tOldQueryPortNumber= ${ gsqueryport } "
fi
if [ " ${ appid } " = = "215360" ] ; then
echo -e "< Master server\tOUTBOUND\t28852\ttcp/udp"
else
echo -e "< Master server\tOUTBOUND\t28900/28902\ttcp/udp"
fi
if [ " ${ appid } " ] ; then
if [ " ${ appid } " = = "223250" ] ; then
echo -e "< Steam\tOUTBOUND\t20610\tudp"
else
echo -e "< Steam\tOUTBOUND\t20660\tudp"
fi
fi
echo -e " > WebAdmin\tINBOUND\t ${ webadminport } \ttcp\tListenPort= ${ webadminport } "
} | column -s $'\t' -t
echo -e ""
echo -e " ${ lightgreen } ${ servername } WebAdmin ${ default } "
printf '%*s\n' " ${ COLUMNS :- $( tput cols) } " '' | tr ' ' =
{
echo -e " ${ blue } WebAdmin enabled:\t ${ default } ${ webadminenabled } "
echo -e " ${ blue } WebAdmin url:\t ${ default } http:// ${ ip } : ${ webadminport } "
echo -e " ${ blue } WebAdmin username:\t ${ default } ${ webadminuser } "
echo -e " ${ blue } WebAdmin password:\t ${ default } ${ webadminpass } "
} | column -s $'\t' -t
}
fn_details_ark( ) {
echo -e "netstat -atunp | grep ShooterGame"
echo -e ""
{
echo -e "DESCRIPTION\tDIRECTION\tPORT\tPROTOCOL\tINI VARIABLE"
echo -e " > Game\tINBOUND\t ${ port } \tudp\tPort= ${ port } "
echo -e " > Query\tINBOUND\t ${ queryport } \tudp "
} | column -s $'\t' -t
}
# Run checks and gathers details to display.
fn_display_details( ) {
check.sh
info_config.sh
info_distro.sh
info_glibc.sh
info_parms.sh
fn_details_os
fn_details_performance
fn_details_disk
fn_details_gameserver
fn_details_script
fn_details_backup
# Some game servers do not have parms.
if [ " ${ gamename } " != "TeamSpeak 3" ] && [ " ${ engine } " != "avalanche" ] && [ " ${ engine } " != "dontstarve" ] && [ " ${ engine } " != "projectzomboid" ] ; then
fn_parms
fn_details_commandlineparms
fi
fn_details_ports
# Display details depending on game or engine.
if [ " ${ engine } " = = "avalanche" ] ; then
fn_details_avalanche
elif [ " ${ engine } " = = "dontstarve" ] ; then
fn_details_dontstarve
elif [ " ${ engine } " = = "lwjgl2" ] ; then
fn_details_minecraft
elif [ " ${ engine } " = = "projectzomboid" ] ; then
fn_details_projectzomboid
elif [ " ${ engine } " = = "idtech3" ] ; then
fn_details_idtech3
elif [ " ${ engine } " = = "realvirtuality" ] ; then
fn_details_realvirtuality
elif [ " ${ engine } " = = "seriousengine35" ] ; then
fn_details_seriousengine35
elif [ " ${ engine } " = = "source" ] || [ " ${ engine } " = = "goldsource" ] ; then
fn_details_source
elif [ " ${ engine } " = = "spark" ] ; then
fn_details_spark
elif [ " ${ engine } " = = "starbound" ] ; then
fn_details_starbound
elif [ " ${ engine } " = = "teeworlds" ] ; then
fn_details_teeworlds
elif [ " ${ engine } " = = "terraria" ] ; then
fn_details_terraria
elif [ " ${ engine } " = = "unreal" ] || [ " ${ engine } " = = "unreal2" ] ; then
fn_details_unreal
elif [ " ${ gamename } " = = "ARK: Survivial Evolved" ] ; then
fn_details_ark
elif [ " ${ gamename } " = = "Hurtworld" ] ; then
fn_details_hurtworld
elif [ " ${ gamename } " = = "7 Days To Die" ] ; then
fn_details_sdtd
elif [ " ${ gamename } " = = "TeamSpeak 3" ] ; then
fn_details_teamspeak3
elif [ " ${ gamename } " = = "Mumble" ] ; then
fn_details_mumble
elif [ " ${ gamename } " = = "Rust" ] ; then
fn_details_rust
else
fn_print_error_nl "Unable to detect server engine."
fi
fn_details_statusbottom
}
if [ -z ${ POSTDETAILS } ] ;
then
fn_display_details
core_exit.sh
fi