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