Add versioning files to upgrade command.

Also add preview of which files will be updated and created.
This commit is contained in:
Marcus Whybrow 2012-08-10 04:13:06 +01:00
parent 5fa9d343fe
commit 8618de4edb

168
init/msm
View File

@ -28,7 +28,7 @@
# The Minecraft Server Manager version, use "msm version" to check yours. # The Minecraft Server Manager version, use "msm version" to check yours.
VERSION="0.7.5" VERSION="0.7.4"
# Source, if it exists, the msm profile.d script # Source, if it exists, the msm profile.d script
@ -1962,7 +1962,7 @@ command_update() {
download_file() { download_file() {
local dir_name="$(dirname "${output_dir}/${1}")" local dir_name="$(dirname "${output_dir}/${1}")"
as_user "root" "mkdir -p \"${dir_name}\"" as_user "root" "mkdir -p \"${dir_name}\""
as_user "root" "wget --trust-server-names --no-check-certificate ${SETTINGS_UPDATE_URL}/$1 -O ${output_dir}/$1" as_user "root" "wget --quiet --trust-server-names --no-check-certificate ${SETTINGS_UPDATE_URL}/$1 -O ${output_dir}/$1"
} }
# $1: The newly download file (relative to download dir) # $1: The newly download file (relative to download dir)
@ -1971,11 +1971,25 @@ command_update() {
# since it is different to the new version # since it is different to the new version
compare_file() { compare_file() {
unset RETURN unset RETURN
if diff -q "${output_dir}/$1" "$2" >/dev/null 2>/dev/null; then local new_file
# Make relative URLs absolute, using the download dir
if [[ "$1" =~ ^/ ]]; then
new_file="$1"
else
new_file="${output_dir}/$1"
fi
# If the new file paht is wrong return
[ ! -e "$new_file" ] && return 1
if [ -e "$2" ]; then
if diff -q "$new_file" "$2" >/dev/null 2>/dev/null; then
return 1 return 1
else else
RETURN="$2" RETURN="$2"
fi fi
fi
} }
# Download the latest MSM script and check its verison number # Download the latest MSM script and check its verison number
@ -1988,9 +2002,13 @@ command_update() {
else else
echo "$latest_version is available." echo "$latest_version is available."
### BEGIN Fancy warnings
echo -n "Checking which files need to be updated... " echo -n "Checking which files need to be updated... "
download_file "bash_completion/msm" download_file "bash_completion/msm"
# download_file "versioning/versions.txt" download_file "versioning/versions.txt"
# Downloads all versioning files in the latest MSM version # Downloads all versioning files in the latest MSM version
download_upstream_versions() { download_upstream_versions() {
@ -2011,9 +2029,33 @@ command_update() {
compare_file "init/msm" "$SCRIPT" compare_file "init/msm" "$SCRIPT"
[ ! -z "$RETURN" ] && return 0 [ ! -z "$RETURN" ] && return 0
manager_property VERSIONING_STORAGE_PATH
local version_name regex
regex="/(([^/]+/[^/]+)\.[^/\.]*)$"
while IFS= read -r -d $'\0' path; do while IFS= read -r -d $'\0' path; do
echo "$path" if [[ "$path" =~ $regex ]]; then
done < <(find "${output_dir}/versioning/" -name .${SETTINGS_VERSIONING_FILE_EXTENSION} -mindepth 1 -type f -print0) version_name="${BASH_REMATCH[1]}"
version_name_without_ext="${BASH_REMATCH[2]}"
compare_file "versioning/$version_name" "${SETTINGS_VERSIONING_STORAGE_PATH}/${version_name_without_ext}.${SETTINGS_VERSIONING_FILE_EXTENSION}"
[ ! -z "$RETURN" ] && return 0
fi
done < <(find "${output_dir}/versioning" -mindepth 1 -name \*.${SETTINGS_VERSIONING_FILE_EXTENSION} -type f -print0)
return 1
}
files_need_creating() {
[ ! -e "$COMPLETION" ] && return 0
[ ! -e "$SCRIPT" ] && return 0
manager_property VERSIONING_STORAGE_PATH
local version_name
while IFS= read -r -d $'\0' path; do
if [[ "$path" =~ /([^/]+/[^/]+)\.[^/\.]*$ ]]; then
version_name_without_ext="${BASH_REMATCH[1]}"
[ ! -e "${SETTINGS_VERSIONING_STORAGE_PATH}/${version_name_without_ext}.${SETTINGS_VERSIONING_FILE_EXTENSION}" ] && return 0
fi
done < <(find "${output_dir}/versioning" -mindepth 1 -name \*.${SETTINGS_VERSIONING_FILE_EXTENSION} -type f -print0)
return 1 return 1
} }
@ -2022,6 +2064,7 @@ command_update() {
echo "Done." echo "Done."
local updated="true"
if files_need_updating; then if files_need_updating; then
echo "Updating will overwrite the following files:" echo "Updating will overwrite the following files:"
@ -2030,15 +2073,52 @@ command_update() {
compare_file "init/msm" "$SCRIPT" compare_file "init/msm" "$SCRIPT"
[ ! -z "$RETURN" ] && echo " > The main MSM script: $SCRIPT" [ ! -z "$RETURN" ] && echo " > The main MSM script: $SCRIPT"
manager_property VERSIONING_STORAGE_PATH
local version_name version_path regex
regex="/(([^/]+/[^/]+)\.[^/\.]*)$"
while IFS= read -r -d $'\0' path; do
if [[ "$path" =~ $regex ]]; then
version_name="${BASH_REMATCH[1]}"
version_name_without_ext="${BASH_REMATCH[2]}"
version_path="${SETTINGS_VERSIONING_STORAGE_PATH}/${version_name_without_ext}.${SETTINGS_VERSIONING_FILE_EXTENSION}"
compare_file "versioning/$version_name" "$version_path"
[ ! -z "$RETURN" ] && echo " > Version file: $version_path"
fi
done < <(find "${output_dir}/versioning" -mindepth 1 -name \*.${SETTINGS_VERSIONING_FILE_EXTENSION} -type f -print0)
else else
echo "Strangely, no files need updating. Ah well." updated="true"
fi fi
local v_full v_type v_version local created="false"
for ((v=0; v<$VERSIONS_COUNT; v++)); do if files_need_creating; then
echo " > Versioning file: ${VERSIONS_PATH[$v]}" echo "Updating will create the following files:"
done
[ ! -e "$COMPLETION" ] && echo " > The bash completion script: $COMPLETION"
[ ! -e "$SCRIPT" ] && echo " > The main MSM script: $SCRIPT"
manager_property VERSIONING_STORAGE_PATH
local version_name version_path
while IFS= read -r -d $'\0' path; do
if [[ "$path" =~ /([^/]+/[^/]+)\.[^/\.]*$ ]]; then
version_name="${BASH_REMATCH[1]}"
version_path="${SETTINGS_VERSIONING_STORAGE_PATH}/${version_name}.${SETTINGS_VERSIONING_FILE_EXTENSION}"
[ ! -e "$version_path" ] && echo " > Version file: $version_path"
fi
done < <(find "${output_dir}/versioning" -mindepth 1 -name \*.${SETTINGS_VERSIONING_FILE_EXTENSION} -type f -print0)
else
created="true"
fi
### END Fancy warnings
if ! "$updated" && ! "$created"; then
echo "Strange, no files need updating or creating. Ah well."
else
if [[ ! "$noinput" ]]; then if [[ ! "$noinput" ]]; then
echo -n "Do you want to continue [y/N]: " echo -n "Do you want to continue [y/N]: "
read answer read answer
@ -2050,24 +2130,80 @@ command_update() {
echo "Updating MSM to ${latest_version}:" echo "Updating MSM to ${latest_version}:"
# Overwrite bash completion file # Overwrite bash completion file
local created="false"
compare_file "bash_completion/msm" "$COMPLETION"
if [ ! -z "$RETURN" ] || [ ! -e "$COMPLETION" ]; then
[ ! -e "$COMPLETION" ] && created="true"
local dir="$(dirname "$COMPLETION")" local dir="$(dirname "$COMPLETION")"
as_user "root" "mkdir -p \"${dir}\"" as_user "root" "mkdir -p \"${dir}\""
as_user "root" "mv -f \"${output_dir}/bash_completion/msm\" \"$COMPLETION\"" as_user "root" "mv -f \"${output_dir}/bash_completion/msm\" \"$COMPLETION\""
source "$COMPLETION" source "$COMPLETION"
echo " > Updated: $COMPLETION"
# Overwite the MSM script itself if "$created"; then
local dir="$(dirname "$SCRIPT")" echo " > Created: $COMPLETION"
else
echo " > Updated: $COMPLETION"
fi
fi
# Overwrite the MSM script itself
created="false"
compare_file "init/msm" "$SCRIPT"
if [ ! -z "$RETURN" ] || [ ! -e "$SCRIPT" ]; then
[ ! -e "$SCRIPT" ] && created="true"
dir="$(dirname "$SCRIPT")"
as_user "root" "mkdir -p \"${dir}\"" as_user "root" "mkdir -p \"${dir}\""
as_user "root" "mv -f \"${output_dir}/init/msm\" \"$SCRIPT\"" as_user "root" "mv -f \"${output_dir}/init/msm\" \"$SCRIPT\""
as_user "root" "chmod +x \"$SCRIPT\"" as_user "root" "chmod +x \"$SCRIPT\""
if "$created"; then
echo " > Created: $SCRIPT"
else
echo " > Updated: $SCRIPT" echo " > Updated: $SCRIPT"
fi
fi
# Overwrite the versioning files
manager_property VERSIONING_STORAGE_PATH
manager_property USERNAME
local version_name version_path regex
regex="/(([^/]+/[^/]+)\.[^/\.]*)$"
while IFS= read -r -d $'\0' path; do
created="false"
if [[ "$path" =~ $regex ]]; then
version_name="${BASH_REMATCH[1]}"
version_name_without_ext="${BASH_REMATCH[2]}"
version_path="${SETTINGS_VERSIONING_STORAGE_PATH}/${version_name_without_ext}.${SETTINGS_VERSIONING_FILE_EXTENSION}"
compare_file "${output_dir}/versioning/$version_name" "$version_path"
if [ ! -z "$RETURN" ] || [ ! -e "$version_path" ]; then
[ ! -e "$version_path" ] && created="true"
dir="$(dirname ${SETTINGS_VERSIONING_STORAGE_PATH}/${version_name})"
as_user "root" "mkdir -p \"${dir}\""
as_user "root" "mv -f \"$path\" \"$version_path\""
as_user "root" "chmod +x \"$version_path\""
as_user "root" "chown ${SETTINGS_USERNAME}:${SETTINGS_USERNAME} \"$version_path\""
if "$created"; then
echo " > Created: $version_path"
else
echo " > Updated: $version_path"
fi
fi
fi
done < <(find "${output_dir}/versioning" -mindepth 1 -name \*.${SETTINGS_VERSIONING_FILE_EXTENSION} -type f -print0)
echo "Done." echo "Done."
return 0
else else
echo "MSM was not updated." echo "MSM was not updated."
fi fi
fi fi
fi
} }
# Displays a list of servers # Displays a list of servers
@ -2907,7 +3043,7 @@ register_settings() {
register_setting VERSIONING_FILE_EXTENSION "sh" register_setting VERSIONING_FILE_EXTENSION "sh"
register_setting RAMDISK_STORAGE_PATH "/dev/shm/msm" register_setting RAMDISK_STORAGE_PATH "/dev/shm/msm"
register_setting UPDATE_URL "https://raw.github.com/marcuswhybrow/minecraft-server-manager/latest" register_setting UPDATE_URL "https://raw.github.com/marcuswhybrow/minecraft-server-manager/versioning"
register_setting WORLD_ARCHIVE_PATH "/opt/msm/archives/worlds" register_setting WORLD_ARCHIVE_PATH "/opt/msm/archives/worlds"
register_setting LOG_ARCHIVE_PATH "/opt/msm/archives/logs" register_setting LOG_ARCHIVE_PATH "/opt/msm/archives/logs"
@ -3593,7 +3729,7 @@ interrupt() {
done done
# Clean up the temp directory created for downloads # Clean up the temp directory created for downloads
# as_user "root" "rm -rf \"${output_dir}\"" as_user "root" "rm -rf \"${output_dir}\""
exit exit
} }