committed by
Daniel Gibbs
11 changed files with 375 additions and 2 deletions
@ -0,0 +1,171 @@ |
|||
################################## |
|||
######## Default Settings ######## |
|||
################################## |
|||
# DO NOT EDIT, ANY CHANGES 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. |
|||
|
|||
#### Game Server Settings #### |
|||
|
|||
## Server Parameters | https://docs.linuxgsm.com/configuration/start-parameters#additional-parameters |
|||
fn_parms(){ |
|||
parms="--datapath ${servercfgdir}" |
|||
} |
|||
|
|||
## Release Settings | https://docs.linuxgsm.com/game-servers/vintagestory#release-settings |
|||
# Branch (stable|unstable) |
|||
branch="stable" |
|||
|
|||
#### LinuxGSM Settings #### |
|||
|
|||
## LinuxGSM Stats |
|||
# Send useful stats to LinuxGSM developers. |
|||
# https://docs.linuxgsm.com/configuration/linuxgsm-stats |
|||
# (on|off) |
|||
stats="off" |
|||
|
|||
## 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" |
|||
|
|||
# Discord Alerts | https://docs.linuxgsm.com/alerts/discord |
|||
discordalert="off" |
|||
discordwebhook="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" |
|||
mailgunapiregion="us" |
|||
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" |
|||
pushoveruserkey="userkey" |
|||
|
|||
# Rocket.Chat Alerts | https://docs.linuxgsm.com/alerts/rocket.chat |
|||
rocketchatalert="off" |
|||
rocketchatwebhook="webhook" |
|||
rocketchattoken="" |
|||
|
|||
# Slack Alerts | https://docs.linuxgsm.com/alerts/slack |
|||
slackalert="off" |
|||
slackwebhook="webhook" |
|||
|
|||
# Telegram Alerts | https://docs.linuxgsm.com/alerts/telegram |
|||
# You can add a custom cURL string eg proxy (useful in Russia) in "curlcustomstring". |
|||
# For example "--socks5 ipaddr:port" for socks5 proxy see more in "curl --help". |
|||
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" |
|||
|
|||
## ANSI Colors | https://docs.linuxgsm.com/features/ansi-colors |
|||
ansi="on" |
|||
|
|||
#### Advanced Settings #### |
|||
|
|||
## Message Display Time | https://docs.linuxgsm.com/features/message-display-time |
|||
sleeptime="0.5" |
|||
|
|||
## Stop Mode | https://docs.linuxgsm.com/features/stop-mode |
|||
# 1: tmux kill |
|||
# 2: CTRL+c |
|||
# 3: quit |
|||
# 4: quit 120s |
|||
# 5: stop |
|||
# 6: q |
|||
# 7: exit |
|||
# 8: 7 Days to Die |
|||
# 9: GoldSrc |
|||
# 10: Avorion |
|||
# 11: end |
|||
stopmode="2" |
|||
|
|||
## Query mode |
|||
# 1: session only |
|||
# 2: gamedig (gsquery fallback) |
|||
# 3: gamedig |
|||
# 4: gsquery |
|||
# 5: tcp |
|||
querymode="5" |
|||
querytype="" |
|||
|
|||
## Console type |
|||
consoleverbose="yes" |
|||
consoleinteract="yes" |
|||
|
|||
## Game Server Details |
|||
# Do not edit |
|||
gamename="Vintage Story" |
|||
engine="vintagestory" |
|||
glibc="2.17" |
|||
|
|||
#### Directories #### |
|||
# Edit with care |
|||
|
|||
## Game Server Directories |
|||
systemdir="${serverfiles}" |
|||
executabledir="${systemdir}" |
|||
preexecutable="mono" |
|||
executable="./VintagestoryServer.exe" |
|||
servercfgdir="${serverfiles}/data/${selfname}" |
|||
servercfg="serverconfig.json" |
|||
servercfgdefault="serverconfig.json" |
|||
servercfgfullpath="${servercfgdir}/${servercfg}" |
|||
|
|||
## Backup Directory |
|||
backupdir="${lgsmdir}/backup" |
|||
|
|||
## Logging Directories |
|||
logdir="${rootdir}/log" |
|||
gamelogdir="${vsdataworld}/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" |
Can't render this file because it has a wrong number of fields in line 66.
|
@ -0,0 +1,145 @@ |
|||
#!/bin/bash |
|||
# LinuxGSM update_vintagestory.sh function |
|||
# Author: Christian Birk |
|||
# Website: https://linuxgsm.com |
|||
# Description: Handles updating of Vintage Story servers. |
|||
|
|||
functionselfname="$(basename "$(readlink -f "${BASH_SOURCE[0]}")")" |
|||
|
|||
fn_update_vs_dl(){ |
|||
# get version info for download |
|||
remotebuildresponse=$(curl -s "${apiurl}" | jq --arg version "${remotebuild}" '.[$version].server') |
|||
remotebuildfile=$(echo -e "${remotebuildresponse}" | jq -r '.filename') |
|||
remotebuildlink=$(echo -e "${remotebuildresponse}" | jq -r '.urls.cdn') |
|||
remotebuildmd5=$(echo -e "${remotebuildresponse}" | jq -r '.md5') |
|||
|
|||
# Download and extract files to serverfiles |
|||
fn_fetch_file "${remotebuildlink}" "" "" "" "${tmpdir}" "${remotebuildfile}" "nochmodx" "norun" "force" "${remotebuildmd5}" |
|||
fn_dl_extract "${tmpdir}" "${remotebuildfile}" "${serverfiles}" |
|||
fn_clear_tmp |
|||
} |
|||
|
|||
fn_update_vs_localbuild(){ |
|||
# Gets local build info. |
|||
fn_print_dots "Checking local build: ${remotelocation}" |
|||
# Uses executable to find local build. |
|||
cd "${executabledir}" || exit |
|||
if [ -f "${executable}" ]; then |
|||
localbuild="$(${preexecutable} ${executable} --version | sed '/^[[:space:]]*$/d')" |
|||
fn_print_ok "Checking local build: ${remotelocation}" |
|||
fn_script_log_pass "Checking local build" |
|||
else |
|||
localbuild="0" |
|||
fn_print_error "Checking local build: ${remotelocation}" |
|||
fn_script_log_error "Checking local build" |
|||
fi |
|||
} |
|||
|
|||
fn_update_vs_remotebuild(){ |
|||
if [ "${branch}" == "stable" ]; then |
|||
remotebuild=$(curl -s "${apiurl}" | jq -r '[ to_entries[] ] | .[].key' | grep -Ev "\-rc|\-pre" | sort -r -V | head -1) |
|||
else |
|||
remotebuild=$(curl -s "${apiurl}" | jq -r '[ to_entries[] ] | .[].key' | grep -E "\-rc|\-pre" | sort -r -V | head -1) |
|||
fi |
|||
|
|||
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_vs_compare(){ |
|||
# Removes dots so if statement can compare version numbers. |
|||
fn_print_dots "Checking for update: ${remotelocation}" |
|||
if [ "${localbuild}" != "${remotebuild}" ]||[ "${forceupdate}" == "1" ]; then |
|||
fn_print_ok_nl "Checking for update: ${remotelocation}" |
|||
echo -en "\n" |
|||
echo -e "Update available" |
|||
echo -e "* Local build: ${red}${localbuild}${default}" |
|||
echo -e "* Remote build: ${green}${remotebuild}${default}" |
|||
if [ -n "${branch}" ]; then |
|||
echo -e "* Branch: ${branch}" |
|||
fi |
|||
echo -en "\n" |
|||
fn_script_log_info "Update available" |
|||
fn_script_log_info "Local build: ${localbuild}" |
|||
fn_script_log_info "Remote build: ${remotebuild}" |
|||
fn_script_log_info "${localbuild} > ${remotebuild}" |
|||
|
|||
unset updateonstart |
|||
check_status.sh |
|||
# If server stopped. |
|||
if [ "${status}" == "0" ]; then |
|||
exitbypass=1 |
|||
fn_update_vs_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_vs_dl |
|||
exitbypass=1 |
|||
command_start.sh |
|||
fn_firstcommand_reset |
|||
fi |
|||
unset exitbypass |
|||
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}${default}" |
|||
echo -e "* Remote build: ${green}${remotebuild}${default}" |
|||
if [ -n "${branch}" ]; then |
|||
echo -e "* Branch: ${branch}" |
|||
fi |
|||
echo -en "\n" |
|||
fn_script_log_info "No update available" |
|||
fn_script_log_info "Local build: ${localbuild}" |
|||
fn_script_log_info "Remote build: ${remotebuild}" |
|||
if [ -n "${branch}" ]; then |
|||
fn_script_log_info "Branch: ${branch}" |
|||
fi |
|||
fi |
|||
} |
|||
|
|||
# The location where the builds are checked and downloaded. |
|||
remotelocation="vintagestory.at" |
|||
apiurl="http://api.${remotelocation}/stable-unstable.json" |
|||
localversionfile="${datadir}/vintagestoryversion" |
|||
|
|||
if [ "${firstcommandname}" == "INSTALL" ]; then |
|||
fn_update_vs_remotebuild |
|||
fn_update_vs_dl |
|||
else |
|||
fn_print_dots "Checking for update" |
|||
fn_print_dots "Checking for update: ${remotelocation}" |
|||
fn_script_log_info "Checking for update: ${remotelocation}" |
|||
fn_update_vs_localbuild |
|||
fn_update_vs_remotebuild |
|||
fn_update_vs_compare |
|||
fi |
Loading…
Reference in new issue