Merge pull request #142 from v2fly/develop

pull/148/head
IceCodeNew 2020-09-25 16:56:30 +08:00 committed by GitHub
commit ddc1abdb7b
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 30 additions and 16 deletions

View File

@ -23,10 +23,6 @@ JSON_PATH=${JSON_PATH:-/usr/local/etc/v2ray}
# Set this variable only if you are starting v2ray with multiple configuration files: # Set this variable only if you are starting v2ray with multiple configuration files:
# export JSONS_PATH='/usr/local/etc/v2ray' # export JSONS_PATH='/usr/local/etc/v2ray'
red=$(tput setaf 1)
green=$(tput setaf 2)
reset=$(tput sgr0)
curl() { curl() {
$(type -P curl) -L -q --retry 5 --retry-delay 10 --retry-max-time 60 "$@" $(type -P curl) -L -q --retry 5 --retry-delay 10 --retry-max-time 60 "$@"
} }
@ -107,18 +103,23 @@ identify_the_operating_system_and_architecture() {
if [[ "$(type -P apt)" ]]; then if [[ "$(type -P apt)" ]]; then
PACKAGE_MANAGEMENT_INSTALL='apt install -y --no-install-recommends' PACKAGE_MANAGEMENT_INSTALL='apt install -y --no-install-recommends'
PACKAGE_MANAGEMENT_REMOVE='apt purge -y --auto-remove' PACKAGE_MANAGEMENT_REMOVE='apt purge -y --auto-remove'
package_provide_tput='ncurses-bin'
elif [[ "$(type -P dnf)" ]]; then elif [[ "$(type -P dnf)" ]]; then
PACKAGE_MANAGEMENT_INSTALL='dnf install -y' PACKAGE_MANAGEMENT_INSTALL='dnf install -y'
PACKAGE_MANAGEMENT_REMOVE='dnf remove -y' PACKAGE_MANAGEMENT_REMOVE='dnf remove -y'
package_provide_tput='ncurses'
elif [[ "$(type -P yum)" ]]; then elif [[ "$(type -P yum)" ]]; then
PACKAGE_MANAGEMENT_INSTALL='yum install -y' PACKAGE_MANAGEMENT_INSTALL='yum install -y'
PACKAGE_MANAGEMENT_REMOVE='yum remove -y' PACKAGE_MANAGEMENT_REMOVE='yum remove -y'
package_provide_tput='ncurses'
elif [[ "$(type -P zypper)" ]]; then elif [[ "$(type -P zypper)" ]]; then
PACKAGE_MANAGEMENT_INSTALL='zypper install -y --no-recommends' PACKAGE_MANAGEMENT_INSTALL='zypper install -y --no-recommends'
PACKAGE_MANAGEMENT_REMOVE='zypper remove -yu' PACKAGE_MANAGEMENT_REMOVE='zypper remove -yu'
package_provide_tput='ncurses-utils'
elif [[ "$(type -P pacman)" ]]; then elif [[ "$(type -P pacman)" ]]; then
PACKAGE_MANAGEMENT_INSTALL='pacman -Syu --noconfirm' PACKAGE_MANAGEMENT_INSTALL='pacman -Syu --noconfirm'
PACKAGE_MANAGEMENT_REMOVE='pacman -Rsun --noconfirm' PACKAGE_MANAGEMENT_REMOVE='pacman -Rsun --noconfirm'
package_provide_tput='ncurses'
else else
echo "error: The script does not support the package manager in this operating system." echo "error: The script does not support the package manager in this operating system."
exit 1 exit 1
@ -179,12 +180,13 @@ judgment_parameters() {
} }
install_software() { install_software() {
COMPONENT="$1" package_name="$1"
type -P "$COMPONENT" > /dev/null 2>&1 && return file_to_detect="$2"
if ${PACKAGE_MANAGEMENT_INSTALL} "$COMPONENT"; then type -P "$file_to_detect" > /dev/null 2>&1 && return
echo "info: $COMPONENT is installed." if ${PACKAGE_MANAGEMENT_INSTALL} "$package_name"; then
echo "info: $package_name is installed."
else else
echo "error: Installation of $COMPONENT failed, please check your network." echo "error: Installation of $package_name failed, please check your network."
exit 1 exit 1
fi fi
} }
@ -436,12 +438,13 @@ remove_v2ray() {
if [[ -n "$(pidof v2ray)" ]]; then if [[ -n "$(pidof v2ray)" ]]; then
stop_v2ray stop_v2ray
fi fi
NAME="$1"
"rm" /usr/local/bin/v2ray "rm" /usr/local/bin/v2ray
"rm" /usr/local/bin/v2ctl "rm" /usr/local/bin/v2ctl
"rm" -r "$DAT_PATH" "rm" -r "$DAT_PATH"
"rm" /etc/systemd/system/v2ray.service "rm" '/etc/systemd/system/v2ray.service'
"rm" /etc/systemd/system/v2ray@.service "rm" '/etc/systemd/system/v2ray@.service'
"rm" -r '/etc/systemd/system/v2ray.service.d'
"rm" -r '/etc/systemd/system/v2ray@.service.d'
if [[ "$?" -ne '0' ]]; then if [[ "$?" -ne '0' ]]; then
echo 'error: Failed to remove V2Ray.' echo 'error: Failed to remove V2Ray.'
exit 1 exit 1
@ -451,11 +454,17 @@ remove_v2ray() {
echo "removed: $DAT_PATH" echo "removed: $DAT_PATH"
echo 'removed: /etc/systemd/system/v2ray.service' echo 'removed: /etc/systemd/system/v2ray.service'
echo 'removed: /etc/systemd/system/v2ray@.service' echo 'removed: /etc/systemd/system/v2ray@.service'
echo 'removed: /etc/systemd/system/v2ray.service.d'
echo 'removed: /etc/systemd/system/v2ray@.service.d'
echo 'Please execute the command: systemctl disable v2ray' echo 'Please execute the command: systemctl disable v2ray'
echo "You may need to execute a command to remove dependent software: $PACKAGE_MANAGEMENT_REMOVE curl unzip" echo "You may need to execute a command to remove dependent software: $PACKAGE_MANAGEMENT_REMOVE curl unzip"
echo 'info: V2Ray has been removed.' echo 'info: V2Ray has been removed.'
echo 'info: If necessary, manually delete the configuration and log files.' echo 'info: If necessary, manually delete the configuration and log files.'
echo "info: e.g., $JSON_PATH and /var/log/v2ray/ ..." if [[ -n "$JSONS_PATH" ]]; then
echo "info: e.g., $JSONS_PATH and /var/log/v2ray/ ..."
else
echo "info: e.g., $JSON_PATH and /var/log/v2ray/ ..."
fi
exit 0 exit 0
fi fi
else else
@ -483,6 +492,11 @@ main() {
identify_the_operating_system_and_architecture identify_the_operating_system_and_architecture
judgment_parameters "$@" judgment_parameters "$@"
install_software "$package_provide_tput" 'tput'
red=$(tput setaf 1)
green=$(tput setaf 2)
reset=$(tput sgr0)
# Parameter information # Parameter information
[[ "$HELP" -eq '1' ]] && show_help [[ "$HELP" -eq '1' ]] && show_help
[[ "$CHECK" -eq '1' ]] && check_update [[ "$CHECK" -eq '1' ]] && check_update
@ -497,11 +511,11 @@ main() {
echo 'warn: Install V2Ray from a local file, but still need to make sure the network is available.' echo 'warn: Install V2Ray from a local file, but still need to make sure the network is available.'
echo -n 'warn: Please make sure the file is valid because we cannot confirm it. (Press any key) ...' echo -n 'warn: Please make sure the file is valid because we cannot confirm it. (Press any key) ...'
read read
install_software unzip install_software 'unzip' 'unzip'
decompression "$LOCAL_FILE" decompression "$LOCAL_FILE"
else else
# Normal way # Normal way
install_software curl install_software 'curl' 'curl'
get_version get_version
NUMBER="$?" NUMBER="$?"
if [[ "$NUMBER" -eq '0' ]] || [[ "$FORCE" -eq '1' ]] || [[ "$NUMBER" -eq 2 ]]; then if [[ "$NUMBER" -eq '0' ]] || [[ "$FORCE" -eq '1' ]] || [[ "$NUMBER" -eq 2 ]]; then
@ -512,7 +526,7 @@ main() {
echo "removed: $TMP_DIRECTORY" echo "removed: $TMP_DIRECTORY"
exit 0 exit 0
fi fi
install_software unzip install_software 'unzip' 'unzip'
decompression "$ZIP_FILE" decompression "$ZIP_FILE"
elif [[ "$NUMBER" -eq '1' ]]; then elif [[ "$NUMBER" -eq '1' ]]; then
echo "info: No new version. The current version of V2Ray is $CURRENT_VERSION ." echo "info: No new version. The current version of V2Ray is $CURRENT_VERSION ."