Browse Source
Co-authored-by: Nate Berkopec <[email protected]> Co-authored-by: Frisasky <[email protected]>pull/3007/head
committed by
GitHub
21 changed files with 447 additions and 60 deletions
@ -0,0 +1,172 @@ |
|||
################################## |
|||
######## Default Settings ######## |
|||
################################## |
|||
# DO NOT EDIT WILL BE OVERWRITTEN! |
|||
# Copy settings from here and use them in either |
|||
# common.cfg - applies settings to every instance |
|||
# [instance].cfg - applies settings to a specific instance |
|||
|
|||
#### Server Settings #### |
|||
|
|||
## SteamCMD Login | https://docs.linuxgsm.com/steamcmd#steamcmd-login |
|||
steamuser="username" |
|||
steampass='password' |
|||
|
|||
## Server Start Settings | https://docs.linuxgsm.com/configuration/start-parameters |
|||
ip="0.0.0.0" |
|||
port="27960" |
|||
defaultmap="ffa_bespin" |
|||
|
|||
## Server Start Command | https://docs.linuxgsm.com/configuration/start-parameters#additional-parameters |
|||
fn_parms(){ |
|||
parms="+set sv_punkbuster 0 +set fs_basepath ${serverfiles} +set net_ip ${ip} +set net_port ${port} +exec ${servercfg} +map ${defaultmap}" |
|||
} |
|||
|
|||
#### LinuxGSM Settings #### |
|||
|
|||
## Notification Alerts |
|||
# (on|off) |
|||
|
|||
# Display IP | https://docs.linuxgsm.com/alerts#display-ip |
|||
displayip="" |
|||
|
|||
# More info | https://docs.linuxgsm.com/alerts#more-info |
|||
postalert="off" |
|||
postdays="7" |
|||
posttarget="https://hastebin.com" |
|||
|
|||
# Discord Alerts | https://docs.linuxgsm.com/alerts/discord |
|||
discordalert="off" |
|||
discordwebhook="webhook" |
|||
|
|||
# Slack Alerts | https://docs.linuxgsm.com/alerts/slack |
|||
slackalert="off" |
|||
slackwebhook="webhook" |
|||
|
|||
# Email Alerts | https://docs.linuxgsm.com/alerts/email |
|||
emailalert="off" |
|||
email="[email protected]" |
|||
emailfrom="" |
|||
|
|||
# IFTTT Alerts | https://docs.linuxgsm.com/alerts/ifttt |
|||
iftttalert="off" |
|||
ifttttoken="accesstoken" |
|||
iftttevent="linuxgsm_alert" |
|||
|
|||
# Mailgun Email Alerts | https://docs.linuxgsm.com/alerts/mailgun |
|||
mailgunalert="off" |
|||
mailguntoken="accesstoken" |
|||
mailgundomain="example.com" |
|||
mailgunemailfrom="[email protected]" |
|||
mailgunemail="[email protected]" |
|||
|
|||
# Pushbullet Alerts | https://docs.linuxgsm.com/alerts/pushbullet |
|||
pushbulletalert="off" |
|||
pushbullettoken="accesstoken" |
|||
channeltag="" |
|||
|
|||
# Pushover Alerts | https://docs.linuxgsm.com/alerts/pushover |
|||
pushoveralert="off" |
|||
pushovertoken="accesstoken" |
|||
|
|||
# Telegram Alerts | https://docs.linuxgsm.com/alerts/telegram |
|||
# You can add a custom cURL string eg proxy (useful in Russia) or else in "curlcustomstring". |
|||
# like a "--socks5 ipaddr:port" for socks5 proxy see more in "curl --help", if you not need |
|||
# any custom string in curl - simple ignore this parameter. |
|||
telegramalert="off" |
|||
telegramtoken="accesstoken" |
|||
telegramchatid="" |
|||
curlcustomstring="" |
|||
|
|||
## Updating | https://docs.linuxgsm.com/commands/update |
|||
updateonstart="off" |
|||
|
|||
## Backup | https://docs.linuxgsm.com/commands/backup |
|||
maxbackups="4" |
|||
maxbackupdays="30" |
|||
stoponbackup="on" |
|||
|
|||
## Logging | https://docs.linuxgsm.com/features/logging |
|||
consolelogging="on" |
|||
logdays="7" |
|||
|
|||
## Monitor | https://docs.linuxgsm.com/commands/monitor |
|||
# Query delay time |
|||
querydelay="1" |
|||
|
|||
#### LinuxGSM Advanced Settings #### |
|||
|
|||
# ANSI Colors |
|||
ansi="on" |
|||
|
|||
# Message Display Time |
|||
sleeptime="0.5" |
|||
|
|||
# Stop Mode | https://docs.linuxgsm.com/steamcmd/stopmode |
|||
# 1: tmux kill |
|||
# 2: CTRL+c |
|||
# 3: quit |
|||
# 4: quit 120s |
|||
# 5: stop |
|||
# 6: q |
|||
# 7: exit |
|||
# 8: 7 Days to Die |
|||
# 9: Gold Source |
|||
# 10: Teamspeak 3 |
|||
stopmode="3" |
|||
|
|||
## Query mode |
|||
# 1: session only |
|||
# 2: gamedig + gsquery |
|||
# 3: gamedig |
|||
# 4: gsquery |
|||
# 5: tcp |
|||
querymode="2" |
|||
querytype="protocol-quake3" |
|||
|
|||
## Console type |
|||
consoleverbose="yes" |
|||
consoleinteract="yes" |
|||
|
|||
## SteamCMD Settings |
|||
# Server appid |
|||
appid="6030" |
|||
# SteamCMD Branch | https://docs.linuxgsm.com/steamcmd/branch |
|||
branch="" |
|||
# Master Server | https://docs.linuxgsm.com/steamcmd/steam-master-server |
|||
steammaster="true" |
|||
|
|||
## LinuxGSM Server Details |
|||
# Do not edit |
|||
gamename="Jedi Knight II: Jedi Outcast" |
|||
engine="idtech3" |
|||
glibc="2.15" |
|||
|
|||
#### Directories #### |
|||
# Edit with care |
|||
|
|||
## Server Specific Directories |
|||
systemdir="${serverfiles}/GameData" |
|||
executabledir="${systemdir}" |
|||
executable="./jk2mvded" |
|||
servercfg="${selfname}.cfg" |
|||
servercfgdefault="server.cfg" |
|||
servercfgdir="${systemdir}" |
|||
servercfgfullpath="${servercfgdir}/${servercfg}" |
|||
|
|||
## Backup Directory |
|||
backupdir="${rootdir}/backups" |
|||
|
|||
## Logging Directories |
|||
logdir="${rootdir}/log" |
|||
gamelogdir="${systemdir}/logs" |
|||
lgsmlogdir="${logdir}/script" |
|||
consolelogdir="${logdir}/console" |
|||
lgsmlog="${lgsmlogdir}/${selfname}-script.log" |
|||
consolelog="${consolelogdir}/${selfname}-console.log" |
|||
alertlog="${lgsmlogdir}/${selfname}-alert.log" |
|||
postdetailslog="${lgsmlogdir}/${selfname}-postdetails.log" |
|||
|
|||
## Logs Naming |
|||
lgsmlogdate="${lgsmlogdir}/${selfname}-script-$(date '+%Y-%m-%d-%H:%M:%S').log" |
|||
consolelogdate="${consolelogdir}/${selfname}-console-$(date '+%Y-%m-%d-%H:%M:%S').log" |
|
@ -0,0 +1,171 @@ |
|||
#!/bin/bash |
|||
# LinuxGSM update_jk2.sh function |
|||
# Author: Daniel Gibbs |
|||
# Website: https://linuxgsm.com |
|||
# Description: Handles updating of jk2 servers. |
|||
|
|||
local commandname="UPDATE" |
|||
local commandaction="Update" |
|||
local function_selfname="$(basename "$(readlink -f "${BASH_SOURCE[0]}")")" |
|||
|
|||
fn_update_jk2_dl(){ |
|||
fn_fetch_file "https://github.com/mvdevs/jk2mv/releases/download/${remotebuild}/jk2mv-v${remotebuild}-dedicated.zip" "" "" "" "${tmpdir}" "jk2mv-${remotebuild}-dedicated.zip" "" "norun" "noforce" "nomd5" |
|||
fn_dl_extract "${tmpdir}" "jk2mv-${remotebuild}-dedicated.zip" "${tmpdir}/jk2mv-v${remotebuild}-dedicated" |
|||
echo -e "copying to ${serverfiles}...\c" |
|||
cp -R "${tmpdir}/jk2mv-v${remotebuild}-dedicated/linux-amd64/jk2mvded"* "${serverfiles}/GameData" |
|||
local exitcode=$? |
|||
if [ "${exitcode}" == "0" ]; then |
|||
fn_print_ok_eol_nl |
|||
fn_script_log_pass "Copying to ${serverfiles}" |
|||
fn_clear_tmp |
|||
else |
|||
fn_print_fail_eol_nl |
|||
fn_script_log_fatal "Copying to ${serverfiles}" |
|||
core_exit.sh |
|||
fi |
|||
} |
|||
|
|||
fn_update_jk2_localbuild(){ |
|||
# Gets local build info. |
|||
fn_print_dots "Checking local build: ${remotelocation}" |
|||
# Uses log file to gather info. |
|||
# Log is generated and cleared on startup but filled on shutdown. |
|||
localbuild=$(grep "\"version\"" "${consolelogdir}"/* 2>/dev/null | sed 's/.*://' | awk '{print $1}' | head -n 1) |
|||
if [ -z "${localbuild}" ]; then |
|||
fn_print_error "Checking local build: ${remotelocation}" |
|||
fn_print_error_nl "Checking local build: ${remotelocation}: no log files containing version info" |
|||
fn_print_info_nl "Checking local build: ${remotelocation}: forcing server restart" |
|||
fn_script_log_error "No log files containing version info" |
|||
fn_script_log_info "Forcing server restart" |
|||
|
|||
check_status.sh |
|||
# If server stopped. |
|||
if [ "${status}" == "0" ]; then |
|||
exitbypass=1 |
|||
command_start.sh |
|||
fn_firstcommand_reset |
|||
sleep 3 |
|||
exitbypass=1 |
|||
command_stop.sh |
|||
fn_firstcommand_reset |
|||
# If server started. |
|||
else |
|||
exitbypass=1 |
|||
command_stop.sh |
|||
fn_firstcommand_reset |
|||
fi |
|||
fi |
|||
|
|||
if [ -z "${localbuild}" ]; then |
|||
localbuild=$(grep Version "$(ls -tr "${consolelogdir}"/* 2>/dev/null)" | tail -1 | sed 's/.*Version //') |
|||
fi |
|||
|
|||
if [ -z "${localbuild}" ]; then |
|||
localbuild="0" |
|||
fn_print_error "Checking local build: ${remotelocation}: waiting for local build: missing local build info" |
|||
fn_script_log_error "Missing local build info" |
|||
fn_script_log_error "Set localbuild to 0" |
|||
else |
|||
fn_print_ok "Checking local build: ${remotelocation}" |
|||
fn_script_log_pass "Checking local build" |
|||
fi |
|||
} |
|||
|
|||
fn_update_jk2_remotebuild(){ |
|||
# Gets remote build info. |
|||
remotebuild=$(curl -s "https://api.github.com/repos/mvdevs/jk2mv/releases/latest" | grep dedicated.zip | tail -1 | awk -F"/" '{ print $8 }') |
|||
if [ "${firstcommandname}" != "INSTALL" ]; then |
|||
fn_print_dots "Checking remote build: ${remotelocation}" |
|||
# Checks if remotebuild variable has been set. |
|||
if [ -z "${remotebuild}" ]||[ "${remotebuild}" == "null" ]; then |
|||
fn_print_fail "Checking remote build: ${remotelocation}" |
|||
fn_script_log_fatal "Checking remote build" |
|||
core_exit.sh |
|||
else |
|||
fn_print_ok "Checking remote build: ${remotelocation}" |
|||
fn_script_log_pass "Checking remote build" |
|||
fi |
|||
else |
|||
# Checks if remotebuild variable has been set. |
|||
if [ -z "${remotebuild}" ]||[ "${remotebuild}" == "null" ]; then |
|||
fn_print_failure "Unable to get remote build" |
|||
fn_script_log_fatal "Unable to get remote build" |
|||
core_exit.sh |
|||
fi |
|||
fi |
|||
} |
|||
|
|||
fn_update_jk2_compare(){ |
|||
# Removes dots so if statement can compare version numbers. |
|||
fn_print_dots "Checking for update: ${remotelocation}" |
|||
localbuilddigit=$(echo -e "${localbuild}" | tr -cd '[:digit:]') |
|||
remotebuilddigit=$(echo -e "${remotebuild}" | tr -cd '[:digit:]') |
|||
if [ "${localbuilddigit}" -ne "${remotebuilddigit}" ]||[ "${forceupdate}" == "1" ]; then |
|||
fn_print_ok_nl "Checking for update: ${remotelocation}" |
|||
echo -en "\n" |
|||
echo -e "Update available" |
|||
echo -e "* Local build: ${red}${localbuild} ${jk2arch}${default}" |
|||
echo -e "* Remote build: ${green}${remotebuild} ${jk2arch}${default}" |
|||
echo -en "\n" |
|||
fn_script_log_info "Update available" |
|||
fn_script_log_info "Local build: ${localbuild} ${jk2arch}" |
|||
fn_script_log_info "Remote build: ${remotebuild} ${jk2arch}" |
|||
fn_script_log_info "${localbuild} > ${remotebuild}" |
|||
|
|||
unset updateonstart |
|||
check_status.sh |
|||
# If server stopped. |
|||
if [ "${status}" == "0" ]; then |
|||
exitbypass=1 |
|||
fn_update_jk2_dl |
|||
exitbypass=1 |
|||
command_start.sh |
|||
exitbypass=1 |
|||
command_stop.sh |
|||
fn_firstcommand_reset |
|||
# If server started. |
|||
else |
|||
fn_print_restart_warning |
|||
exitbypass=1 |
|||
command_stop.sh |
|||
fn_firstcommand_reset |
|||
exitbypass=1 |
|||
fn_update_jk2_dl |
|||
exitbypass=1 |
|||
command_start.sh |
|||
fn_firstcommand_reset |
|||
fi |
|||
date +%s > "${lockdir}/lastupdate.lock" |
|||
alert="update" |
|||
alert.sh |
|||
else |
|||
fn_print_ok_nl "Checking for update: ${remotelocation}" |
|||
echo -en "\n" |
|||
echo -e "No update available" |
|||
echo -e "* Local build: ${green}${localbuild} ${jk2arch}${default}" |
|||
echo -e "* Remote build: ${green}${remotebuild} ${jk2arch}${default}" |
|||
echo -en "\n" |
|||
fn_script_log_info "No update available" |
|||
fn_script_log_info "Local build: ${localbuild} ${jk2arch}" |
|||
fn_script_log_info "Remote build: ${remotebuild} ${jk2arch}" |
|||
fi |
|||
} |
|||
|
|||
# The location where the builds are checked and downloaded. |
|||
remotelocation="jk2mv.org" |
|||
|
|||
# Game server architecture. |
|||
jk2arch="x64" |
|||
|
|||
if [ "${firstcommandname}" == "INSTALL" ]; then |
|||
fn_update_jk2_remotebuild |
|||
fn_update_jk2_dl |
|||
else |
|||
update_steamcmd.sh |
|||
fn_print_dots "Checking for update" |
|||
fn_print_dots "Checking for update: ${remotelocation}" |
|||
fn_script_log_info "Checking for update: ${remotelocation}" |
|||
fn_update_jk2_localbuild |
|||
fn_update_jk2_remotebuild |
|||
fn_update_jk2_compare |
|||
fi |
Loading…
Reference in new issue