mirror of
https://github.com/XTLS/Xray-install.git
synced 2025-03-14 02:13:51 +00:00
Refactor install-release.sh to improve error handling and streamline checks (#82)
- Changed exit calls to return statements for better control flow. - Updated user and OS checks to enhance script robustness. - Improved network request handling for fetching release versions. - Enhanced readability and maintainability of the code.
This commit is contained in:
parent
652637b1eb
commit
c83088d6c9
1 changed files with 36 additions and 27 deletions
|
@ -117,16 +117,18 @@ systemd_cat_config() {
|
|||
|
||||
check_if_running_as_root() {
|
||||
# If you want to run as another user, please modify $EUID to be owned by this user
|
||||
if [[ "$EUID" -ne '0' ]]; then
|
||||
if [[ "$(id -u)" -eq 0 ]]; then
|
||||
return 0
|
||||
else
|
||||
echo "error: You must run this script as root!"
|
||||
exit 1
|
||||
return 1
|
||||
fi
|
||||
}
|
||||
|
||||
identify_the_operating_system_and_architecture() {
|
||||
if [[ "$(uname)" != 'Linux' ]]; then
|
||||
echo "error: This operating system is not supported."
|
||||
exit 1
|
||||
return 1
|
||||
fi
|
||||
case "$(uname -m)" in
|
||||
'i386' | 'i686')
|
||||
|
@ -176,12 +178,12 @@ identify_the_operating_system_and_architecture() {
|
|||
;;
|
||||
*)
|
||||
echo "error: The architecture is not supported."
|
||||
exit 1
|
||||
return 1
|
||||
;;
|
||||
esac
|
||||
if [[ ! -f '/etc/os-release' ]]; then
|
||||
echo "error: Don't use outdated Linux distributions."
|
||||
exit 1
|
||||
return 1
|
||||
fi
|
||||
# Do not combine this judgment condition with the following judgment condition.
|
||||
## Be aware of Linux distribution like Gentoo, which kernel supports switch between Systemd and OpenRC.
|
||||
|
@ -191,7 +193,7 @@ identify_the_operating_system_and_architecture() {
|
|||
true
|
||||
else
|
||||
echo "error: Only Linux distributions using systemd are supported."
|
||||
exit 1
|
||||
return 1
|
||||
fi
|
||||
if [[ "$(type -P apt)" ]]; then
|
||||
PACKAGE_MANAGEMENT_INSTALL='apt -y --no-install-recommends install'
|
||||
|
@ -219,7 +221,7 @@ identify_the_operating_system_and_architecture() {
|
|||
package_provide_tput='ncurses'
|
||||
else
|
||||
echo "error: The script does not support the package manager in this operating system."
|
||||
exit 1
|
||||
return 1
|
||||
fi
|
||||
}
|
||||
|
||||
|
@ -256,7 +258,7 @@ judgment_parameters() {
|
|||
'--version')
|
||||
if [[ -z "$2" ]]; then
|
||||
echo "error: Please specify the correct version."
|
||||
exit 1
|
||||
return 1
|
||||
fi
|
||||
temp_version='1'
|
||||
SPECIFIED_VERSION="$2"
|
||||
|
@ -272,7 +274,7 @@ judgment_parameters() {
|
|||
local_install='1'
|
||||
if [[ -z "$2" ]]; then
|
||||
echo "error: Please specify the correct local file."
|
||||
exit 1
|
||||
return 1
|
||||
fi
|
||||
LOCAL_FILE="$2"
|
||||
shift
|
||||
|
@ -280,7 +282,7 @@ judgment_parameters() {
|
|||
'-p' | '--proxy')
|
||||
if [[ -z "$2" ]]; then
|
||||
echo "error: Please specify the proxy server address."
|
||||
exit 1
|
||||
return 1
|
||||
fi
|
||||
PROXY="$2"
|
||||
shift
|
||||
|
@ -288,7 +290,7 @@ judgment_parameters() {
|
|||
'-u' | '--install-user')
|
||||
if [[ -z "$2" ]]; then
|
||||
echo "error: Please specify the install user.}"
|
||||
exit 1
|
||||
return 1
|
||||
fi
|
||||
INSTALL_USER="$2"
|
||||
shift
|
||||
|
@ -310,7 +312,7 @@ judgment_parameters() {
|
|||
;;
|
||||
*)
|
||||
echo "$0: unknown option -- -"
|
||||
exit 1
|
||||
return 1
|
||||
;;
|
||||
esac
|
||||
shift
|
||||
|
@ -319,11 +321,11 @@ judgment_parameters() {
|
|||
INSTALL='1'
|
||||
elif ((INSTALL+INSTALL_GEODATA+HELP+CHECK+REMOVE>1)); then
|
||||
echo 'You can only choose one action.'
|
||||
exit 1
|
||||
return 1
|
||||
fi
|
||||
if [[ "$INSTALL" -eq '1' ]] && ((temp_version+local_install+REINSTALL+BETA>1)); then
|
||||
echo "--version,--reinstall,--beta and --local can't be used together."
|
||||
exit 1
|
||||
return 1
|
||||
fi
|
||||
}
|
||||
|
||||
|
@ -372,7 +374,10 @@ get_latest_version() {
|
|||
# Get Xray latest release version number
|
||||
local tmp_file
|
||||
tmp_file="$(mktemp)"
|
||||
if ! curl -x "${PROXY}" -sS -H "Accept: application/vnd.github.v3+json" -o "$tmp_file" 'https://api.github.com/repos/XTLS/Xray-core/releases/latest'; then
|
||||
local url='https://api.github.com/repos/XTLS/Xray-core/releases/latest'
|
||||
if curl -x "${PROXY}" -sSfLo "$tmp_file" -H "Accept: application/vnd.github.v3+json" "$url"; then
|
||||
echo "get release list success"
|
||||
else
|
||||
"rm" "$tmp_file"
|
||||
echo 'error: Failed to get release list, please check your network.'
|
||||
exit 1
|
||||
|
@ -390,14 +395,16 @@ get_latest_version() {
|
|||
fi
|
||||
"rm" "$tmp_file"
|
||||
RELEASE_LATEST="v${RELEASE_LATEST#v}"
|
||||
if ! curl -x "${PROXY}" -sS -H "Accept: application/vnd.github.v3+json" -o "$tmp_file" 'https://api.github.com/repos/XTLS/Xray-core/releases'; then
|
||||
if curl -x "${PROXY}" -sSfLo "$tmp_file" -H "Accept: application/vnd.github.v3+json" "$url"; then
|
||||
echo "get release list success"
|
||||
else
|
||||
"rm" "$tmp_file"
|
||||
echo 'error: Failed to get release list, please check your network.'
|
||||
exit 1
|
||||
fi
|
||||
local releases_list
|
||||
releases_list=($(sed 'y/,/\n/' "$tmp_file" | grep 'tag_name' | awk -F '"' '{print $4}'))
|
||||
if [[ "${#releases_list[@]}" -eq '0' ]]; then
|
||||
readarray -t releases_list < <(sed 'y/,/\n/' "$tmp_file" | grep 'tag_name' | awk -F '"' '{print $4}')
|
||||
if [[ "${#releases_list[@]}" -eq 0 ]]; then
|
||||
if grep -q "API rate limit exceeded" "$tmp_file"; then
|
||||
echo "error: github API rate limit exceeded"
|
||||
else
|
||||
|
@ -407,14 +414,16 @@ get_latest_version() {
|
|||
"rm" "$tmp_file"
|
||||
exit 1
|
||||
fi
|
||||
local i
|
||||
for i in "${!releases_list[@]}"
|
||||
do
|
||||
local i url_zip
|
||||
for i in "${!releases_list[@]}"; do
|
||||
releases_list["$i"]="v${releases_list[$i]#v}"
|
||||
grep -q "https://github.com/XTLS/Xray-core/releases/download/${releases_list[$i]}/Xray-linux-$MACHINE.zip" "$tmp_file" && break
|
||||
url_zip="https://github.com/XTLS/Xray-core/releases/download/${releases_list[$i]}/Xray-linux-$MACHINE.zip"
|
||||
if grep -q "$url_zip" "$tmp_file"; then
|
||||
PRE_RELEASE_LATEST="${releases_list[$i]}"
|
||||
break
|
||||
fi
|
||||
done
|
||||
"rm" "$tmp_file"
|
||||
PRE_RELEASE_LATEST="${releases_list[$i]}"
|
||||
}
|
||||
|
||||
version_gt() {
|
||||
|
@ -422,7 +431,7 @@ version_gt() {
|
|||
}
|
||||
|
||||
download_xray() {
|
||||
DOWNLOAD_LINK="https://github.com/XTLS/Xray-core/releases/download/${INSTALL_VERSION}/Xray-linux-${MACHINE}.zip"
|
||||
local DOWNLOAD_LINK="https://github.com/XTLS/Xray-core/releases/download/${INSTALL_VERSION}/Xray-linux-${MACHINE}.zip"
|
||||
echo "Downloading Xray archive: $DOWNLOAD_LINK"
|
||||
if curl -f -x "${PROXY}" -R -H 'Cache-Control: no-cache' -o "$ZIP_FILE" "$DOWNLOAD_LINK"; then
|
||||
echo "ok."
|
||||
|
@ -811,9 +820,9 @@ show_help() {
|
|||
}
|
||||
|
||||
main() {
|
||||
check_if_running_as_root
|
||||
identify_the_operating_system_and_architecture
|
||||
judgment_parameters "$@"
|
||||
check_if_running_as_root || return 1
|
||||
identify_the_operating_system_and_architecture || return 1
|
||||
judgment_parameters "$@" || return 1
|
||||
|
||||
install_software "$package_provide_tput" 'tput'
|
||||
red=$(tput setaf 1)
|
||||
|
|
Loading…
Add table
Reference in a new issue