Compare commits
4 Commits
e5a01d86b3
...
main
| Author | SHA1 | Date | |
|---|---|---|---|
| 8004daa9f0 | |||
| 95ac54ed54 | |||
| 87deb832bd | |||
| d567af0235 |
46
minecraft-server/restore-backup.sh
Normal file
46
minecraft-server/restore-backup.sh
Normal file
@@ -0,0 +1,46 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
set -eo pipefail
|
||||||
|
|
||||||
|
RCLONE_CONFIG="rclone.conf"
|
||||||
|
RCLONE_TARGET="minecraft:"
|
||||||
|
WORLDS_DIR="spigot/worlds"
|
||||||
|
WORLDS_DIR_BACKUP="$WORLDS_DIR.backup"
|
||||||
|
ARCHIVE_PREFIX="etc/mcserver/worlds"
|
||||||
|
SERVICE_NAME="spigot"
|
||||||
|
|
||||||
|
archive=$(rclone --config "$RCLONE_CONFIG" lsf "$RCLONE_TARGET" | sort --reverse | fzf --cycle)
|
||||||
|
|
||||||
|
if [[ -z $archive ]]; then
|
||||||
|
echo "error: no archive file has been selected!" >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
target_dir=$(mktemp --directory)
|
||||||
|
target_archive="$target_dir/$archive"
|
||||||
|
|
||||||
|
echo "Downloading archive $archive to $target_archive ..."
|
||||||
|
rclone --config "$RCLONE_CONFIG" copy "$RCLONE_TARGET$archive" "$target_dir" --progress
|
||||||
|
|
||||||
|
if [[ -d $WORLDS_DIR_BACKUP ]]; then
|
||||||
|
echo "Deleting old worlds dir backup ($WORLDS_DIR_BACKUP) ..."
|
||||||
|
rm -rf "$WORLDS_DIR_BACKUP"
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "Un-zipping archive to $target_dir ..."
|
||||||
|
unzip "$target_archive" -d "$target_dir" 1>/dev/null
|
||||||
|
|
||||||
|
echo "Stopping server ..."
|
||||||
|
docker compose stop "$SERVICE_NAME"
|
||||||
|
|
||||||
|
echo "Backing up worlds dir ($WORLDS_DIR -> $WORLDS_DIR_BACKUP) ..."
|
||||||
|
mv "$WORLDS_DIR" "$WORLDS_DIR_BACKUP"
|
||||||
|
|
||||||
|
echo "Restoring world ($target_dir/$ARCHIVE_PREFIX -> $WORLDS_DIR) ..."
|
||||||
|
mv "$target_dir/$ARCHIVE_PREFIX" "$WORLDS_DIR"
|
||||||
|
|
||||||
|
echo "Re-starting server ..."
|
||||||
|
docker compose start "$SERVICE_NAME"
|
||||||
|
|
||||||
|
echo "Cleaning up ..."
|
||||||
|
rm -rf "$target_dir"
|
||||||
41
powershell/elden-ring-lp-backup.ps1
Normal file
41
powershell/elden-ring-lp-backup.ps1
Normal file
@@ -0,0 +1,41 @@
|
|||||||
|
# This simple powershell script backups up my elden ring save to a remote git repository on my NAS
|
||||||
|
# by creating a commit and pushing it.
|
||||||
|
# After that, OBS, ER Death Counter as well as Elden Ring is started if not already running.
|
||||||
|
|
||||||
|
$OBS_PATH = "C:\Program Files\obs-studio\bin\64bit\obs64.exe"
|
||||||
|
$ERDC_PATH = "C:\Program Files (x86)\ER Death Counter\ER_DeathCounter.exe"
|
||||||
|
$ER_SAVE_ID = "76561198077851234"
|
||||||
|
$ER_LAUCH_PATH = "steam://rungameid/1245620"
|
||||||
|
$ER_PROCESS_NAME = "eldenring"
|
||||||
|
|
||||||
|
|
||||||
|
function Open-If-Not-Already {
|
||||||
|
param (
|
||||||
|
[Parameter(Mandatory = $true)]
|
||||||
|
[string]$Path,
|
||||||
|
[string]$ProcessName,
|
||||||
|
[string]$WorkingDirectory = (Get-Location).Path
|
||||||
|
)
|
||||||
|
|
||||||
|
if (-not $ProcessName) {
|
||||||
|
$ProcessName = (Get-Item $Path).BaseName
|
||||||
|
}
|
||||||
|
|
||||||
|
if (-not (Get-Process -Name "$ProcessName" -ErrorAction SilentlyContinue)) {
|
||||||
|
Write-Output "Starting $ProcessName ($Path) ..."
|
||||||
|
Start-Process "$Path" -WorkingDirectory "$WorkingDirectory"
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
Write-Output "$ProcessName is already running."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
$timestamp = Get-Date -Format "yyyy-MM-dd_HH-mm-ss"
|
||||||
|
|
||||||
|
git -C "${HOME}\AppData\Roaming\EldenRing\${ER_SAVE_ID}" commit --all --message "backup-${timestamp}"
|
||||||
|
git -C "${HOME}\AppData\Roaming\EldenRing\${ER_SAVE_ID}" push origin main
|
||||||
|
|
||||||
|
Open-If-Not-Already -Path "$OBS_PATH" -WorkingDirectory (Get-Item "$OBS_PATH").DirectoryName
|
||||||
|
Open-If-Not-Already -Path "$ERDC_PATH"
|
||||||
|
Open-If-Not-Already -Path "$ER_LAUCH_PATH" -ProcessName "$ER_PROCESS_NAME"
|
||||||
Reference in New Issue
Block a user