Merge pull request #142 from v2fly/develop
commit
ddc1abdb7b
|
@ -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 ."
|
||||||
|
|
Loading…
Reference in New Issue