Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/MHSanaei/3x-ui.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--README.md7
-rw-r--r--install.sh43
-rw-r--r--x-ui.sh120
3 files changed, 119 insertions, 51 deletions
diff --git a/README.md b/README.md
index 8398216f..d10b9d19 100644
--- a/README.md
+++ b/README.md
@@ -27,7 +27,7 @@ certbot renew --dry-run
# Default settings
- Port: 2053
-- username and password will be generated randomly you can see them after you install it (x-ui "7")
+- username and password will be generated randomly if you skip to modify your own security(x-ui "7")
- database path: /etc/x-ui/x-ui.db
before you set ssl on settings
@@ -39,13 +39,14 @@ After you set ssl on settings
# Enable Traffic For Users:
**copy and paste to xray Configuration :** (you don't need to do this if you have a fresh install)
-- [for enable traffic](https://raw.githubusercontent.com/MHSanaei/3x-ui/main/media/for%20enable%20traffic.txt)
-- [for enable traffic+block all iran ip address](https://raw.githubusercontent.com/MHSanaei/3x-ui/main/media/for%20enable%20traffic%2Bblock%20all%20iran%20ip.txt)
+- [for enable traffic](https://raw.githubusercontent.com/mhsanaei/3x-ui/main/media/for%20enable%20traffic.txt)
+- [for enable traffic+block all iran ip address](https://raw.githubusercontent.com/mhsanaei/3x-ui/main/media/for%20enable%20traffic%2Bblock%20all%20iran%20ip.txt)
# Suggestion System
- Ubuntu 20.04+
- Debian 10+
- CentOS 8+
+- Fedora 29+
# Pictures
diff --git a/install.sh b/install.sh
index 87d8f85c..9ea3eec1 100644
--- a/install.sh
+++ b/install.sh
@@ -10,9 +10,12 @@ cur_dir=$(pwd)
# check root
[[ $EUID -ne 0 ]] && echo -e "${red}Fatal error:${plain} Please run this script with root privilege \n " && exit 1
-# check os
+# Check OS
if [[ -f /etc/redhat-release ]]; then
release="centos"
+ if grep -q "Fedora" /etc/redhat-release; then
+ release="fedora"
+ fi
elif cat /etc/issue | grep -Eqi "debian"; then
release="debian"
elif cat /etc/issue | grep -Eqi "ubuntu"; then
@@ -25,6 +28,8 @@ elif cat /proc/version | grep -Eqi "ubuntu"; then
release="ubuntu"
elif cat /proc/version | grep -Eqi "centos|red hat|redhat"; then
release="centos"
+elif grep -q "Fedora" /etc/*-release; then
+ release="fedora"
else
echo -e "${red} Check system OS failed, please contact the author! ${plain}\n" && exit 1
fi
@@ -49,7 +54,7 @@ fi
os_version=""
-# os version
+# get OS version
if [[ -f /etc/os-release ]]; then
os_version=$(awk -F'[= ."]' '/VERSION_ID/{print $3}' /etc/os-release)
fi
@@ -57,18 +62,28 @@ if [[ -z "$os_version" && -f /etc/lsb-release ]]; then
os_version=$(awk -F'[= ."]+' '/DISTRIB_RELEASE/{print $2}' /etc/lsb-release)
fi
-if [[ x"${release}" == x"centos" ]]; then
- if [[ ${os_version} -le 7 ]]; then
- echo -e "${red} Please use CentOS 8 or higher ${plain}\n" && exit 1
- fi
-elif [[ x"${release}" == x"ubuntu" ]]; then
- if [[ ${os_version} -lt 20 ]]; then
- echo -e "${red} Please use Ubuntu 20 or higher ${plain}\n" && exit 1
- fi
-elif [[ x"${release}" == x"debian" ]]; then
- if [[ ${os_version} -lt 9 ]]; then
- echo -e "${red} Please use Debian 10 or higher ${plain}\n" && exit 1
- fi
+# set minimum version number for each OS
+case ${release} in
+ centos)
+ min_version=8
+ ;;
+ ubuntu)
+ min_version=20
+ ;;
+ debian)
+ min_version=10
+ ;;
+ fedora)
+ min_version=29
+ ;;
+ *)
+ echo -e "${red} Unsupported OS ${plain}\n" && exit 1
+ ;;
+esac
+
+# check if OS version meets minimum version requirement
+if [[ ${os_version} -lt ${min_version} ]]; then
+ echo -e "${red} Please use ${release^} ${min_version} or higher ${plain}\n" && exit 1
fi
install_base() {
diff --git a/x-ui.sh b/x-ui.sh
index 8fdde3b0..c1dfa67e 100644
--- a/x-ui.sh
+++ b/x-ui.sh
@@ -20,48 +20,76 @@ function LOGI() {
# check root
[[ $EUID -ne 0 ]] && LOGE "ERROR: You must be root to run this script! \n" && exit 1
-# check os
+# Check OS and set release variable
if [[ -f /etc/redhat-release ]]; then
- release="centos"
-elif cat /etc/issue | grep -Eqi "debian"; then
+ if grep -Eqi "CentOS" /etc/redhat-release; then
+ release="centos"
+ elif grep -Eqi "Fedora" /etc/redhat-release; then
+ release="fedora"
+ fi
+elif grep -Eqi "debian" /etc/issue; then
release="debian"
-elif cat /etc/issue | grep -Eqi "ubuntu"; then
+elif grep -Eqi "ubuntu" /etc/issue; then
release="ubuntu"
-elif cat /etc/issue | grep -Eqi "centos|red hat|redhat"; then
+elif grep -Eqi "centos" /etc/issue; then
release="centos"
-elif cat /proc/version | grep -Eqi "debian"; then
+elif grep -Eqi "debian" /proc/version; then
release="debian"
-elif cat /proc/version | grep -Eqi "ubuntu"; then
+elif grep -Eqi "ubuntu" /proc/version; then
release="ubuntu"
-elif cat /proc/version | grep -Eqi "centos|red hat|redhat"; then
+elif grep -Eqi "centos" /proc/version; then
release="centos"
+elif grep -Eqi "fedora" /proc/version; then
+ release="fedora"
else
- LOGE "check system OS failed,please contact with author! \n" && exit 1
+ echo "Failed to check the system OS, please contact the author!" >&2
+ exit 1
fi
+echo "The OS release is: $release"
+
os_version=""
# os version
if [[ -f /etc/os-release ]]; then
os_version=$(awk -F'[= ."]' '/VERSION_ID/{print $3}' /etc/os-release)
-fi
-if [[ -z "$os_version" && -f /etc/lsb-release ]]; then
+elif [[ -f /etc/lsb-release ]]; then
os_version=$(awk -F'[= ."]+' '/DISTRIB_RELEASE/{print $2}' /etc/lsb-release)
+elif [[ -f /etc/fedora-release ]]; then
+ os_version=$(awk -F'[= ]+' '/release/{print $3}' /etc/fedora-release)
fi
-if [[ x"${release}" == x"centos" ]]; then
- if [[ ${os_version} -le 6 ]]; then
- LOGE "please use CentOS 7 or higher version! \n" && exit 1
- fi
-elif [[ x"${release}" == x"ubuntu" ]]; then
- if [[ ${os_version} -lt 16 ]]; then
- LOGE "please use Ubuntu 16 or higher version!\n" && exit 1
- fi
-elif [[ x"${release}" == x"debian" ]]; then
- if [[ ${os_version} -lt 8 ]]; then
- LOGE "please use Debian 8 or higher version!\n" && exit 1
- fi
-fi
+case "${release}" in
+ centos)
+ if [[ ${os_version} -le 8 ]]; then
+ echo "Please use CentOS 8 or higher version!"
+ exit 2
+ fi
+ ;;
+ ubuntu)
+ if [[ ${os_version} -lt 20 ]]; then
+ echo "Please use Ubuntu 20 or higher version!"
+ exit 2
+ fi
+ ;;
+ debian)
+ if [[ ${os_version} -lt 10 ]]; then
+ echo "Please use Debian 10 or higher version!"
+ exit 2
+ fi
+ ;;
+ fedora)
+ if [[ ${os_version} -lt 29 ]]; then
+ echo "Please use Fedora 29 or higher version!"
+ exit 2
+ fi
+ ;;
+ *)
+ echo "Unknown release type '${release}'"
+ exit 2
+ ;;
+esac
+
confirm() {
if [[ $# > 1 ]]; then
@@ -288,17 +316,41 @@ show_log() {
fi
}
-migrate_v2_ui() {
- /usr/local/x-ui/x-ui v2-ui
+enable_bbr() {
- before_show_menu
-}
+if grep -q "net.core.default_qdisc=fq" /etc/sysctl.conf && grep -q "net.ipv4.tcp_congestion_control=bbr" /etc/sysctl.conf; then
+ echo -e "${green}BBR is already enabled!${plain}"
+ exit 0
+fi
+
+# Check the OS and install necessary packages
+if [[ "$(cat /etc/os-release | grep -E '^ID=' | awk -F '=' '{print $2}')" == "ubuntu" ]]; then
+ sudo apt-get update && sudo apt-get install -yqq --no-install-recommends ca-certificates
+elif [[ "$(cat /etc/os-release | grep -E '^ID=' | awk -F '=' '{print $2}')" == "debian" ]]; then
+ sudo apt-get update && sudo apt-get install -yqq --no-install-recommends ca-certificates
+elif [[ "$(cat /etc/os-release | grep -E '^ID=' | awk -F '=' '{print $2}')" == "fedora" ]]; then
+ sudo dnf -y update && sudo dnf -y install ca-certificates
+elif [[ "$(cat /etc/os-release | grep -E '^ID=' | awk -F '=' '{print $2}')" == "centos" ]]; then
+ sudo yum -y update && sudo yum -y install ca-certificates
+else
+ echo "Unsupported operating system. Please check the script and install the necessary packages manually."
+ exit 1
+fi
+
+# Enable BBR
+echo "net.core.default_qdisc=fq" | sudo tee -a /etc/sysctl.conf
+echo "net.ipv4.tcp_congestion_control=bbr" | sudo tee -a /etc/sysctl.conf
+
+# Apply changes
+sudo sysctl -p
+
+# Verify that BBR is enabled
+if [[ $(sysctl net.ipv4.tcp_congestion_control | awk '{print $3}') == "bbr" ]]; then
+ echo -e "${green}BBR has been enabled successfully.${plain}"
+else
+ echo -e "${red}Failed to enable BBR. Please check your system configuration.${plain}"
+fi
-install_bbr() {
- # temporary workaround for installing bbr
- bash <(curl -L -s https://raw.githubusercontent.com/teddysun/across/master/bbr.sh)
- echo ""
- before_show_menu
}
update_shell() {
@@ -713,7 +765,7 @@ show_menu() {
check_install && disable
;;
15)
- install_bbr
+ enable_bbr
;;
16)
ssl_cert_issue