mirror of
				https://github.com/MHSanaei/3x-ui.git
				synced 2025-10-26 10:04:41 +00:00 
			
		
		
		
	Update
This commit is contained in:
		
							parent
							
								
									f0ca1f0db6
								
							
						
					
					
						commit
						4d4e2d2bd6
					
				
					 2 changed files with 983 additions and 0 deletions
				
			
		
							
								
								
									
										175
									
								
								install.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										175
									
								
								install.sh
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,175 @@ | |||
| #!/bin/bash | ||||
| 
 | ||||
| red='\033[0;31m' | ||||
| green='\033[0;32m' | ||||
| yellow='\033[0;33m' | ||||
| plain='\033[0m' | ||||
| 
 | ||||
| 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 and set release variable | ||||
| if [[ -f /etc/os-release ]]; then | ||||
|     source /etc/os-release | ||||
|     release=$ID | ||||
| elif [[ -f /usr/lib/os-release ]]; then | ||||
|     source /usr/lib/os-release | ||||
|     release=$ID | ||||
| else | ||||
|     echo "Failed to check the system OS, please contact the author!" >&2 | ||||
|     exit 1 | ||||
| fi | ||||
| echo "The OS release is: $release" | ||||
| 
 | ||||
| arch3xui() { | ||||
|     case "$(uname -m)" in | ||||
|         x86_64 | x64 | amd64 ) echo 'amd64' ;; | ||||
|         armv8 | arm64 | aarch64 ) echo 'arm64' ;; | ||||
|         * ) echo -e "${green}Unsupported CPU architecture! ${plain}" && rm -f install.sh && exit 1 ;; | ||||
|     esac | ||||
| } | ||||
| echo "arch: $(arch3xui)" | ||||
| 
 | ||||
| os_version="" | ||||
| os_version=$(grep -i version_id /etc/os-release | cut -d \" -f2 | cut -d . -f1) | ||||
| 
 | ||||
| if [[ "${release}" == "centos" ]]; then | ||||
|     if [[ ${os_version} -lt 8 ]]; then | ||||
|         echo -e "${red} Please use CentOS 8 or higher ${plain}\n" && exit 1 | ||||
|     fi | ||||
| elif [[ "${release}" ==  "ubuntu" ]]; then | ||||
|     if [[ ${os_version} -lt 20 ]]; then | ||||
|         echo -e "${red}please use Ubuntu 20 or higher version!${plain}\n" && exit 1 | ||||
|     fi | ||||
| 
 | ||||
| elif [[ "${release}" == "fedora" ]]; then | ||||
|     if [[ ${os_version} -lt 36 ]]; then | ||||
|         echo -e "${red}please use Fedora 36 or higher version!${plain}\n" && exit 1 | ||||
|     fi | ||||
| 
 | ||||
| elif [[ "${release}" == "debian" ]]; then | ||||
|     if [[ ${os_version} -lt 10 ]]; then | ||||
|         echo -e "${red} Please use Debian 10 or higher ${plain}\n" && exit 1 | ||||
|     fi | ||||
| else | ||||
|     echo -e "${red}Failed to check the OS version, please contact the author!${plain}" && exit 1 | ||||
| fi | ||||
| 
 | ||||
| install_base() { | ||||
|     case "${release}" in | ||||
|         centos|fedora) | ||||
|             yum install -y -q wget curl tar | ||||
|             ;; | ||||
|         *) | ||||
|             apt install -y -q wget curl tar | ||||
|             ;; | ||||
|     esac | ||||
| } | ||||
| 
 | ||||
| #This function will be called when user installed x-ui out of sercurity | ||||
| config_after_install() { | ||||
|     /usr/local/x-ui/x-ui migrate | ||||
|     echo -e "${yellow}Install/update finished! For security it's recommended to modify panel settings ${plain}" | ||||
|     read -p "Do you want to continue with the modification [y/n]? ": config_confirm | ||||
|     if [[ "${config_confirm}" == "y" || "${config_confirm}" == "Y" ]]; then | ||||
|         read -p "Please set up your username:" config_account | ||||
|         echo -e "${yellow}Your username will be:${config_account}${plain}" | ||||
|         read -p "Please set up your password:" config_password | ||||
|         echo -e "${yellow}Your password will be:${config_password}${plain}" | ||||
|         read -p "Please set up the panel port:" config_port | ||||
|         echo -e "${yellow}Your panel port is:${config_port}${plain}" | ||||
|         echo -e "${yellow}Initializing, please wait...${plain}" | ||||
|         /usr/local/x-ui/x-ui setting -username ${config_account} -password ${config_password} | ||||
|         echo -e "${yellow}Account name and password set successfully!${plain}" | ||||
|         /usr/local/x-ui/x-ui setting -port ${config_port} | ||||
|         echo -e "${yellow}Panel port set successfully!${plain}" | ||||
|     else | ||||
|         echo -e "${red}cancel...${plain}" | ||||
|         if [[ ! -f "/etc/x-ui/x-ui.db" ]]; then | ||||
|             local usernameTemp=$(head -c 6 /dev/urandom | base64) | ||||
|             local passwordTemp=$(head -c 6 /dev/urandom | base64) | ||||
|             /usr/local/x-ui/x-ui setting -username ${usernameTemp} -password ${passwordTemp} | ||||
|             echo -e "this is a fresh installation,will generate random login info for security concerns:" | ||||
|             echo -e "###############################################" | ||||
|             echo -e "${green}username:${usernameTemp}${plain}" | ||||
|             echo -e "${green}password:${passwordTemp}${plain}" | ||||
|             echo -e "###############################################" | ||||
|             echo -e "${red}if you forgot your login info,you can type x-ui and then type 7 to check after installation${plain}" | ||||
|         else | ||||
|             echo -e "${red} this is your upgrade,will keep old settings,if you forgot your login info,you can type x-ui and then type 7 to check${plain}" | ||||
|         fi | ||||
|     fi | ||||
| } | ||||
| 
 | ||||
| install_x-ui() { | ||||
|     systemctl stop x-ui | ||||
|     cd /usr/local/ | ||||
| 
 | ||||
|     if [ $# == 0 ]; then | ||||
|         last_version=$(curl -Ls "https://api.github.com/repos/Ptechgithub/3x-ui/releases/latest" | grep '"tag_name":' | sed -E 's/.*"([^"]+)".*/\1/') | ||||
|         if [[ ! -n "$last_version" ]]; then | ||||
|             echo -e "${red}Failed to fetch x-ui version, it maybe due to Github API restrictions, please try it later${plain}" | ||||
|             exit 1 | ||||
|         fi | ||||
|         echo -e "Got x-ui latest version: ${last_version}, beginning the installation..." | ||||
|         wget -N --no-check-certificate -O /usr/local/x-ui-linux-$(arch3xui).tar.gz https://github.com/Ptechgithub/3x-ui/releases/download/${last_version}/x-ui-linux-$(arch3xui).tar.gz | ||||
|         if [[ $? -ne 0 ]]; then | ||||
|             echo -e "${red}Downloading x-ui failed, please be sure that your server can access Github ${plain}" | ||||
|             exit 1 | ||||
|         fi | ||||
|     else | ||||
|         last_version=$1 | ||||
|         url="https://github.com/Ptechgithub/3x-ui/releases/download/${last_version}/x-ui-linux-$(arch3xui).tar.gz" | ||||
|         echo -e "Begining to install x-ui $1" | ||||
|         wget -N --no-check-certificate -O /usr/local/x-ui-linux-$(arch3xui).tar.gz ${url} | ||||
|         if [[ $? -ne 0 ]]; then | ||||
|             echo -e "${red}Download x-ui $1 failed,please check the version exists ${plain}" | ||||
|             exit 1 | ||||
|         fi | ||||
|     fi | ||||
| 
 | ||||
|     if [[ -e /usr/local/x-ui/ ]]; then | ||||
|         rm /usr/local/x-ui/ -rf | ||||
|     fi | ||||
| 
 | ||||
|     tar zxvf x-ui-linux-$(arch3xui).tar.gz | ||||
|     rm x-ui-linux-$(arch3xui).tar.gz -f | ||||
|     cd x-ui | ||||
|     chmod +x x-ui bin/xray-linux-$(arch3xui) | ||||
|     cp -f x-ui.service /etc/systemd/system/ | ||||
|     wget --no-check-certificate -O /usr/bin/x-ui https://raw.githubusercontent.com/Ptechgithub/3x-ui/main/x-ui.sh | ||||
|     chmod +x /usr/local/x-ui/x-ui.sh | ||||
|     chmod +x /usr/bin/x-ui | ||||
|     config_after_install | ||||
|     #echo -e "If it is a new installation, the default web port is ${green}2053${plain}, The username and password are ${green}admin${plain} by default" | ||||
|     #echo -e "Please make sure that this port is not occupied by other procedures,${yellow} And make sure that port 2053 has been released${plain}" | ||||
|     #    echo -e "If you want to modify the 2053 to other ports and enter the x-ui command to modify it, you must also ensure that the port you modify is also released" | ||||
|     #echo -e "" | ||||
|     #echo -e "If it is updated panel, access the panel in your previous way" | ||||
|     #echo -e "" | ||||
|     systemctl daemon-reload | ||||
|     systemctl enable x-ui | ||||
|     systemctl start x-ui | ||||
|     echo -e "${green}x-ui ${last_version}${plain} installation finished, it is running now..." | ||||
|     echo -e "" | ||||
|     echo -e "x-ui control menu usages: " | ||||
|     echo -e "----------------------------------------------" | ||||
|     echo -e "x-ui              - Enter     Admin menu" | ||||
|     echo -e "x-ui start        - Start     x-ui" | ||||
|     echo -e "x-ui stop         - Stop      x-ui" | ||||
|     echo -e "x-ui restart      - Restart   x-ui" | ||||
|     echo -e "x-ui status       - Show      x-ui status" | ||||
|     echo -e "x-ui enable       - Enable    x-ui on system startup" | ||||
|     echo -e "x-ui disable      - Disable   x-ui on system startup" | ||||
|     echo -e "x-ui log          - Check     x-ui logs" | ||||
|     echo -e "x-ui update       - Update    x-ui" | ||||
|     echo -e "x-ui install      - Install   x-ui" | ||||
|     echo -e "x-ui uninstall    - Uninstall x-ui" | ||||
|     echo -e "---------t.me/P_tech2024----------------" | ||||
| } | ||||
| 
 | ||||
| echo -e "${green}Running...${plain}" | ||||
| install_base | ||||
| install_x-ui $1 | ||||
							
								
								
									
										808
									
								
								x-ui.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										808
									
								
								x-ui.sh
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,808 @@ | |||
| #!/bin/bash | ||||
| 
 | ||||
| red='\033[0;31m' | ||||
| green='\033[0;32m' | ||||
| yellow='\033[0;33m' | ||||
| plain='\033[0m' | ||||
| 
 | ||||
| #Add some basic function here | ||||
| function LOGD() { | ||||
|     echo -e "${yellow}[DEG] $* ${plain}" | ||||
| } | ||||
| 
 | ||||
| function LOGE() { | ||||
|     echo -e "${red}[ERR] $* ${plain}" | ||||
| } | ||||
| 
 | ||||
| function LOGI() { | ||||
|     echo -e "${green}[INF] $* ${plain}" | ||||
| } | ||||
| 
 | ||||
| # check root | ||||
| [[ $EUID -ne 0 ]] && LOGE "ERROR: You must be root to run this script! \n" && exit 1 | ||||
| 
 | ||||
| # Check OS and set release variable | ||||
| if [[ -f /etc/os-release ]]; then | ||||
|     source /etc/os-release | ||||
|     release=$ID | ||||
| elif [[ -f /usr/lib/os-release ]]; then | ||||
|     source /usr/lib/os-release | ||||
|     release=$ID | ||||
| else | ||||
|     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=$(grep -i version_id /etc/os-release | cut -d \" -f2 | cut -d . -f1) | ||||
| 
 | ||||
| if [[ "${release}" == "centos" ]]; then | ||||
|     if [[ ${os_version} -lt 8 ]]; then | ||||
|         echo -e "${red} Please use CentOS 8 or higher ${plain}\n" && exit 1 | ||||
|     fi | ||||
| elif [[ "${release}" ==  "ubuntu" ]]; then | ||||
|     if [[ ${os_version} -lt 20 ]]; then | ||||
|         echo -e "${red}please use Ubuntu 20 or higher version! ${plain}\n" && exit 1 | ||||
|     fi | ||||
| elif [[ "${release}" == "fedora" ]]; then | ||||
|     if [[ ${os_version} -lt 36 ]]; then | ||||
|         echo -e "${red}please use Fedora 36 or higher version! ${plain}\n" && exit 1 | ||||
|     fi | ||||
| elif [[ "${release}" == "debian" ]]; then | ||||
|     if [[ ${os_version} -lt 10 ]]; then | ||||
|         echo -e "${red} Please use Debian 10 or higher ${plain}\n" && exit 1 | ||||
|     fi | ||||
| fi | ||||
| 
 | ||||
| confirm() { | ||||
|     if [[ $# > 1 ]]; then | ||||
|         echo && read -p "$1 [Default $2]: " temp | ||||
|         if [[ "${temp}" == "" ]]; then | ||||
|             temp=$2 | ||||
|         fi | ||||
|     else | ||||
|         read -p "$1 [y/n]: " temp | ||||
|     fi | ||||
|     if [[ "${temp}" == "y" || "${temp}" == "Y" ]]; then | ||||
|         return 0 | ||||
|     else | ||||
|         return 1 | ||||
|     fi | ||||
| } | ||||
| 
 | ||||
| confirm_restart() { | ||||
|     confirm "Restart the panel, Attention: Restarting the panel will also restart xray" "y" | ||||
|     if [[ $? == 0 ]]; then | ||||
|         restart | ||||
|     else | ||||
|         show_menu | ||||
|     fi | ||||
| } | ||||
| 
 | ||||
| before_show_menu() { | ||||
|     echo && echo -n -e "${yellow}Press enter to return to the main menu: ${plain}" && read temp | ||||
|     show_menu | ||||
| } | ||||
| 
 | ||||
| install() { | ||||
|     bash <(curl -Ls https://raw.githubusercontent.com/Ptechgithub/3x-ui/main/install.sh) | ||||
|     if [[ $? == 0 ]]; then | ||||
|         if [[ $# == 0 ]]; then | ||||
|             start | ||||
|         else | ||||
|             start 0 | ||||
|         fi | ||||
|     fi | ||||
| } | ||||
| 
 | ||||
| update() { | ||||
|     confirm "This function will forcefully reinstall the latest version, and the data will not be lost. Do you want to continue?" "n" | ||||
|     if [[ $? != 0 ]]; then | ||||
|         LOGE "Cancelled" | ||||
|         if [[ $# == 0 ]]; then | ||||
|             before_show_menu | ||||
|         fi | ||||
|         return 0 | ||||
|     fi | ||||
|     bash <(curl -Ls https://raw.githubusercontent.com/Ptechgithub/3x-ui/main/install.sh) | ||||
|     if [[ $? == 0 ]]; then | ||||
|         LOGI "Update is complete, Panel has automatically restarted " | ||||
|         exit 0 | ||||
|     fi | ||||
| } | ||||
| 
 | ||||
| uninstall() { | ||||
|     confirm "Are you sure you want to uninstall the panel? xray will also uninstalled!" "n" | ||||
|     if [[ $? != 0 ]]; then | ||||
|         if [[ $# == 0 ]]; then | ||||
|             show_menu | ||||
|         fi | ||||
|         return 0 | ||||
|     fi | ||||
|     systemctl stop x-ui | ||||
|     systemctl disable x-ui | ||||
|     rm /etc/systemd/system/x-ui.service -f | ||||
|     systemctl daemon-reload | ||||
|     systemctl reset-failed | ||||
|     rm /etc/x-ui/ -rf | ||||
|     rm /usr/local/x-ui/ -rf | ||||
| 
 | ||||
|     echo "" | ||||
|     echo -e "Uninstalled Successfully, If you want to remove this script, then after exiting the script run ${green}rm /usr/bin/x-ui -f${plain} to delete it." | ||||
|     echo "" | ||||
| 
 | ||||
|     if [[ $# == 0 ]]; then | ||||
|         before_show_menu | ||||
|     fi | ||||
| } | ||||
| 
 | ||||
| reset_user() { | ||||
|     confirm "Are you sure to reset the username and password of the panel?" "n" | ||||
|     if [[ $? != 0 ]]; then | ||||
|         if [[ $# == 0 ]]; then | ||||
|             show_menu | ||||
|         fi | ||||
|         return 0 | ||||
|     fi | ||||
|     read -rp "Please set the login username [default is a random username]: " config_account | ||||
|     [[ -z $config_account ]] && config_account=$(date +%s%N | md5sum | cut -c 1-8) | ||||
|     read -rp "Please set the login password [default is a random password]: " config_password | ||||
|     [[ -z $config_password ]] && config_password=$(date +%s%N | md5sum | cut -c 1-8) | ||||
|     /usr/local/x-ui/x-ui setting -username ${config_account} -password ${config_password} >/dev/null 2>&1 | ||||
|     /usr/local/x-ui/x-ui setting -remove_secret >/dev/null 2>&1 | ||||
|     echo -e "Panel login username has been reset to: ${green} ${config_account} ${plain}" | ||||
|     echo -e "Panel login password has been reset to: ${green} ${config_password} ${plain}" | ||||
|     echo -e "${yellow} Panel login secret token disabled ${plain}" | ||||
|     echo -e "${green} Please use the new login username and password to access the X-UI panel. Also remember them! ${plain}" | ||||
|     confirm_restart | ||||
| } | ||||
| 
 | ||||
| reset_config() { | ||||
|     confirm "Are you sure you want to reset all panel settings, Account data will not be lost, Username and password will not change" "n" | ||||
|     if [[ $? != 0 ]]; then | ||||
|         if [[ $# == 0 ]]; then | ||||
|             show_menu | ||||
|         fi | ||||
|         return 0 | ||||
|     fi | ||||
|     /usr/local/x-ui/x-ui setting -reset | ||||
|     echo -e "All panel settings have been reset to default, Please restart the panel now, and use the default ${green}2053${plain} Port to Access the web Panel" | ||||
|     confirm_restart | ||||
| } | ||||
| 
 | ||||
| check_config() { | ||||
|     info=$(/usr/local/x-ui/x-ui setting -show true) | ||||
|     if [[ $? != 0 ]]; then | ||||
|         LOGE "get current settings error, please check logs" | ||||
|         show_menu | ||||
|     fi | ||||
|     LOGI "${info}" | ||||
| } | ||||
| 
 | ||||
| set_port() { | ||||
|     echo && echo -n -e "Enter port number[1-65535]: " && read port | ||||
|     if [[ -z "${port}" ]]; then | ||||
|         LOGD "Cancelled" | ||||
|         before_show_menu | ||||
|     else | ||||
|         /usr/local/x-ui/x-ui setting -port ${port} | ||||
|         echo -e "The port is set, Please restart the panel now, and use the new port ${green}${port}${plain} to access web panel" | ||||
|         confirm_restart | ||||
|     fi | ||||
| } | ||||
| 
 | ||||
| start() { | ||||
|     check_status | ||||
|     if [[ $? == 0 ]]; then | ||||
|         echo "" | ||||
|         LOGI "Panel is running, No need to start again, If you need to restart, please select restart" | ||||
|     else | ||||
|         systemctl start x-ui | ||||
|         sleep 2 | ||||
|         check_status | ||||
|         if [[ $? == 0 ]]; then | ||||
|             LOGI "x-ui Started Successfully" | ||||
|         else | ||||
|             LOGE "panel Failed to start, Probably because it takes longer than two seconds to start, Please check the log information later" | ||||
|         fi | ||||
|     fi | ||||
| 
 | ||||
|     if [[ $# == 0 ]]; then | ||||
|         before_show_menu | ||||
|     fi | ||||
| } | ||||
| 
 | ||||
| stop() { | ||||
|     check_status | ||||
|     if [[ $? == 1 ]]; then | ||||
|         echo "" | ||||
|         LOGI "Panel stopped, No need to stop again!" | ||||
|     else | ||||
|         systemctl stop x-ui | ||||
|         sleep 2 | ||||
|         check_status | ||||
|         if [[ $? == 1 ]]; then | ||||
|             LOGI "x-ui and xray stopped successfully" | ||||
|         else | ||||
|             LOGE "Panel stop failed, Probably because the stop time exceeds two seconds, Please check the log information later" | ||||
|         fi | ||||
|     fi | ||||
| 
 | ||||
|     if [[ $# == 0 ]]; then | ||||
|         before_show_menu | ||||
|     fi | ||||
| } | ||||
| 
 | ||||
| restart() { | ||||
|     systemctl restart x-ui | ||||
|     sleep 2 | ||||
|     check_status | ||||
|     if [[ $? == 0 ]]; then | ||||
|         LOGI "x-ui and xray Restarted successfully" | ||||
|     else | ||||
|         LOGE "Panel restart failed, Probably because it takes longer than two seconds to start, Please check the log information later" | ||||
|     fi | ||||
|     if [[ $# == 0 ]]; then | ||||
|         before_show_menu | ||||
|     fi | ||||
| } | ||||
| 
 | ||||
| status() { | ||||
|     systemctl status x-ui -l | ||||
|     if [[ $# == 0 ]]; then | ||||
|         before_show_menu | ||||
|     fi | ||||
| } | ||||
| 
 | ||||
| enable() { | ||||
|     systemctl enable x-ui | ||||
|     if [[ $? == 0 ]]; then | ||||
|         LOGI "x-ui Set to boot automatically on startup successfully" | ||||
|     else | ||||
|         LOGE "x-ui Failed to set Autostart" | ||||
|     fi | ||||
| 
 | ||||
|     if [[ $# == 0 ]]; then | ||||
|         before_show_menu | ||||
|     fi | ||||
| } | ||||
| 
 | ||||
| disable() { | ||||
|     systemctl disable x-ui | ||||
|     if [[ $? == 0 ]]; then | ||||
|         LOGI "x-ui Autostart Cancelled successfully" | ||||
|     else | ||||
|         LOGE "x-ui Failed to cancel autostart" | ||||
|     fi | ||||
| 
 | ||||
|     if [[ $# == 0 ]]; then | ||||
|         before_show_menu | ||||
|     fi | ||||
| } | ||||
| 
 | ||||
| show_log() { | ||||
|     journalctl -u x-ui.service -e --no-pager -f | ||||
|     if [[ $# == 0 ]]; then | ||||
|         before_show_menu | ||||
|     fi | ||||
| } | ||||
| 
 | ||||
| enable_bbr() { | ||||
|     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 | ||||
| } | ||||
| 
 | ||||
| update_shell() { | ||||
|     wget -O /usr/bin/x-ui -N --no-check-certificate https://github.com/Ptechgithub/3x-ui/raw/main/x-ui.sh | ||||
|     if [[ $? != 0 ]]; then | ||||
|         echo "" | ||||
|         LOGE "Failed to download script, Please check whether the machine can connect Github" | ||||
|         before_show_menu | ||||
|     else | ||||
|         chmod +x /usr/bin/x-ui | ||||
|         LOGI "Upgrade script succeeded, Please rerun the script" && exit 0 | ||||
|     fi | ||||
| } | ||||
| 
 | ||||
| # 0: running, 1: not running, 2: not installed | ||||
| check_status() { | ||||
|     if [[ ! -f /etc/systemd/system/x-ui.service ]]; then | ||||
|         return 2 | ||||
|     fi | ||||
|     temp=$(systemctl status x-ui | grep Active | awk '{print $3}' | cut -d "(" -f2 | cut -d ")" -f1) | ||||
|     if [[ "${temp}" == "running" ]]; then | ||||
|         return 0 | ||||
|     else | ||||
|         return 1 | ||||
|     fi | ||||
| } | ||||
| 
 | ||||
| check_enabled() { | ||||
|     temp=$(systemctl is-enabled x-ui) | ||||
|     if [[ "${temp}" == "enabled" ]]; then | ||||
|         return 0 | ||||
|     else | ||||
|         return 1 | ||||
|     fi | ||||
| } | ||||
| 
 | ||||
| check_uninstall() { | ||||
|     check_status | ||||
|     if [[ $? != 2 ]]; then | ||||
|         echo "" | ||||
|         LOGE "Panel installed, Please do not reinstall" | ||||
|         if [[ $# == 0 ]]; then | ||||
|             before_show_menu | ||||
|         fi | ||||
|         return 1 | ||||
|     else | ||||
|         return 0 | ||||
|     fi | ||||
| } | ||||
| 
 | ||||
| check_install() { | ||||
|     check_status | ||||
|     if [[ $? == 2 ]]; then | ||||
|         echo "" | ||||
|         LOGE "Please install the panel first" | ||||
|         if [[ $# == 0 ]]; then | ||||
|             before_show_menu | ||||
|         fi | ||||
|         return 1 | ||||
|     else | ||||
|         return 0 | ||||
|     fi | ||||
| } | ||||
| 
 | ||||
| show_status() { | ||||
|     check_status | ||||
|     case $? in | ||||
|     0) | ||||
|         echo -e "Panel state: ${green}Running${plain}" | ||||
|         show_enable_status | ||||
|         ;; | ||||
|     1) | ||||
|         echo -e "Panel state: ${yellow}Not Running${plain}" | ||||
|         show_enable_status | ||||
|         ;; | ||||
|     2) | ||||
|         echo -e "Panel state: ${red}Not Installed${plain}" | ||||
|         ;; | ||||
|     esac | ||||
|     show_xray_status | ||||
| } | ||||
| 
 | ||||
| show_enable_status() { | ||||
|     check_enabled | ||||
|     if [[ $? == 0 ]]; then | ||||
|         echo -e "Start automatically: ${green}Yes${plain}" | ||||
|     else | ||||
|         echo -e "Start automatically: ${red}No${plain}" | ||||
|     fi | ||||
| } | ||||
| 
 | ||||
| check_xray_status() { | ||||
|     count=$(ps -ef | grep "xray-linux" | grep -v "grep" | wc -l) | ||||
|     if [[ count -ne 0 ]]; then | ||||
|         return 0 | ||||
|     else | ||||
|         return 1 | ||||
|     fi | ||||
| } | ||||
| 
 | ||||
| show_xray_status() { | ||||
|     check_xray_status | ||||
|     if [[ $? == 0 ]]; then | ||||
|         echo -e "xray state: ${green}Running${plain}" | ||||
|     else | ||||
|         echo -e "xray state: ${red}Not Running${plain}" | ||||
|     fi | ||||
| } | ||||
| 
 | ||||
| open_ports() { | ||||
|     if ! command -v ufw &> /dev/null | ||||
|     then | ||||
|         echo "ufw firewall is not installed. Installing now..." | ||||
|         sudo apt-get update | ||||
|         sudo apt-get install -y ufw | ||||
|     else | ||||
|         echo "ufw firewall is already installed" | ||||
|     fi | ||||
| 
 | ||||
|     # Check if the firewall is inactive | ||||
|     if sudo ufw status | grep -q "Status: active"; then | ||||
|         echo "firewall is already active" | ||||
|     else | ||||
|         # Open the necessary ports | ||||
|         sudo ufw allow ssh | ||||
|         sudo ufw allow http | ||||
|         sudo ufw allow https | ||||
|         sudo ufw allow 2053/tcp | ||||
| 
 | ||||
|         # Enable the firewall | ||||
|         sudo ufw --force enable | ||||
|     fi | ||||
| 
 | ||||
|     # Prompt the user to enter a list of ports | ||||
|     read -p "Enter the ports you want to open (e.g. 80,443,2053 or range 400-500): " ports | ||||
| 
 | ||||
|     # Check if the input is valid | ||||
|     if ! [[ $ports =~ ^([0-9]+|[0-9]+-[0-9]+)(,([0-9]+|[0-9]+-[0-9]+))*$ ]]; then | ||||
|         echo "Error: Invalid input. Please enter a comma-separated list of ports or a range of ports (e.g. 80,443,2053 or 400-500)." >&2; exit 1 | ||||
|     fi | ||||
| 
 | ||||
|     # Open the specified ports using ufw | ||||
|     IFS=',' read -ra PORT_LIST <<< "$ports" | ||||
|     for port in "${PORT_LIST[@]}"; do | ||||
|         if [[ $port == *-* ]]; then | ||||
|         # Split the range into start and end ports | ||||
|         start_port=$(echo $port | cut -d'-' -f1) | ||||
|         end_port=$(echo $port | cut -d'-' -f2) | ||||
|         # Loop through the range and open each port | ||||
|         for ((i=start_port; i<=end_port; i++)); do | ||||
|             sudo ufw allow $i | ||||
|         done | ||||
|         else | ||||
|         sudo ufw allow "$port" | ||||
|         fi | ||||
|     done | ||||
| 
 | ||||
|     # Confirm that the ports are open | ||||
|     sudo ufw status | grep $ports | ||||
| } | ||||
| 
 | ||||
| update_geo() { | ||||
|     local defaultBinFolder="/usr/local/x-ui/bin" | ||||
|     read -p "Please enter x-ui bin folder path. Leave blank for default. (Default: '${defaultBinFolder}')" binFolder | ||||
|     binFolder=${binFolder:-${defaultBinFolder}} | ||||
|     if [[ ! -d ${binFolder} ]]; then | ||||
|         LOGE "Folder ${binFolder} not exists!" | ||||
|         LOGI "making bin folder: ${binFolder}..." | ||||
|         mkdir -p ${binFolder} | ||||
|     fi | ||||
| 
 | ||||
|     systemctl stop x-ui | ||||
|     cd ${binFolder} | ||||
|     rm -f geoip.dat geosite.dat iran.dat | ||||
|     wget -N https://github.com/Loyalsoldier/v2ray-rules-dat/releases/latest/download/geoip.dat | ||||
|     wget -N https://github.com/Loyalsoldier/v2ray-rules-dat/releases/latest/download/geosite.dat | ||||
|     wget -N https://github.com/bootmortis/iran-hosted-domains/releases/latest/download/iran.dat | ||||
|     systemctl start x-ui | ||||
|     echo -e "${green}Geosite.dat + Geoip.dat + Iran.dat have been updated successfully in bin folder '${binfolder}'!${plain}" | ||||
|     before_show_menu | ||||
| } | ||||
| 
 | ||||
| install_acme() { | ||||
|     cd ~ | ||||
|     LOGI "install acme..." | ||||
|     curl https://get.acme.sh | sh | ||||
|     if [ $? -ne 0 ]; then | ||||
|         LOGE "install acme failed" | ||||
|         return 1 | ||||
|     else | ||||
|         LOGI "install acme succeed" | ||||
|     fi | ||||
|     return 0 | ||||
| } | ||||
| 
 | ||||
| #method for standalone mode | ||||
| ssl_cert_issue() { | ||||
|     #check for acme.sh first | ||||
|     if ! command -v ~/.acme.sh/acme.sh &>/dev/null; then | ||||
|         echo "acme.sh could not be found. we will install it" | ||||
|         install_acme | ||||
|         if [ $? -ne 0 ]; then | ||||
|             LOGE "install acme failed, please check logs" | ||||
|             exit 1 | ||||
|         fi | ||||
|     fi | ||||
|     #install socat second | ||||
|     if [[ "${release}" == "centos" ]] || [[ "${release}" == "fedora" ]] ; then | ||||
|         yum install socat -y | ||||
|     else | ||||
|         apt install socat -y | ||||
|     fi | ||||
|     if [ $? -ne 0 ]; then | ||||
|         LOGE "install socat failed,please check logs" | ||||
|         exit 1 | ||||
|     else | ||||
|         LOGI "install socat succeed..." | ||||
|     fi | ||||
| 
 | ||||
|     #get the domain here,and we need verify it | ||||
|     local domain="" | ||||
|     read -p "Please enter your domain name:" domain | ||||
|     LOGD "your domain is:${domain},check it..." | ||||
|     #here we need to judge whether there exists cert already | ||||
|     local currentCert=$(~/.acme.sh/acme.sh --list | tail -1 | awk '{print $1}') | ||||
|     if [ ${currentCert} == ${domain} ]; then | ||||
|         local certInfo=$(~/.acme.sh/acme.sh --list) | ||||
|         LOGE "system already have certs here,can not issue again,current certs details:" | ||||
|         LOGI "$certInfo" | ||||
|         exit 1 | ||||
|     else | ||||
|         LOGI "your domain is ready for issuing cert now..." | ||||
|     fi | ||||
| 	 | ||||
| 	#create a directory for install cert | ||||
| 	certPath="/root/cert/${domain}" | ||||
| 	if [ ! -d "$certPath" ]; then | ||||
| 		mkdir -p "$certPath" | ||||
| 	else | ||||
| 		rm -rf "$certPath" | ||||
| 		mkdir -p "$certPath" | ||||
| 	fi | ||||
| 	 | ||||
|     #get needed port here | ||||
|     local WebPort=80 | ||||
|     read -p "please choose which port do you use,default will be 80 port:" WebPort | ||||
|     if [[ ${WebPort} -gt 65535 || ${WebPort} -lt 1 ]]; then | ||||
|         LOGE "your input ${WebPort} is invalid,will use default port" | ||||
|     fi | ||||
|     LOGI "will use port:${WebPort} to issue certs,please make sure this port is open..." | ||||
|     #NOTE:This should be handled by user | ||||
|     #open the port and kill the occupied progress | ||||
|     ~/.acme.sh/acme.sh --set-default-ca --server letsencrypt | ||||
|     ~/.acme.sh/acme.sh --issue -d ${domain} --standalone --httpport ${WebPort} | ||||
|     if [ $? -ne 0 ]; then | ||||
|         LOGE "issue certs failed,please check logs" | ||||
|         rm -rf ~/.acme.sh/${domain} | ||||
|         exit 1 | ||||
|     else | ||||
|         LOGE "issue certs succeed,installing certs..." | ||||
|     fi | ||||
|     #install cert | ||||
|     ~/.acme.sh/acme.sh --installcert -d ${domain} \ | ||||
|         --key-file /root/cert/${domain}/privkey.pem \ | ||||
|         --fullchain-file /root/cert/${domain}/fullchain.pem | ||||
| 
 | ||||
|     if [ $? -ne 0 ]; then | ||||
|         LOGE "install certs failed,exit" | ||||
|         rm -rf ~/.acme.sh/${domain} | ||||
|         exit 1 | ||||
|     else | ||||
|         LOGI "install certs succeed,enable auto renew..." | ||||
|     fi | ||||
| 	 | ||||
| 	~/.acme.sh/acme.sh --upgrade --auto-upgrade | ||||
| 	if [ $? -ne 0 ]; then | ||||
| 		LOGE "auto renew failed, certs details:" | ||||
| 		ls -lah cert/* | ||||
| 		chmod 755 $certPath/* | ||||
| 		exit 1 | ||||
| 	else | ||||
| 		LOGI "auto renew succeed, certs details:" | ||||
| 		ls -lah cert/* | ||||
| 		chmod 755 $certPath/* | ||||
| 	fi | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| warp_fixchatgpt() { | ||||
|     curl -fsSL https://gist.githubusercontent.com/hamid-gh98/dc5dd9b0cc5b0412af927b1ccdb294c7/raw/install_warp_proxy.sh | bash | ||||
|     echo "" | ||||
|     before_show_menu | ||||
| } | ||||
| 
 | ||||
| run_speedtest() { | ||||
|     # Check if Speedtest is already installed | ||||
|     if ! command -v speedtest &> /dev/null; then | ||||
|         # If not installed, install it | ||||
|         if command -v dnf &> /dev/null; then | ||||
|             sudo dnf install -y curl | ||||
|             curl -s https://packagecloud.io/install/repositories/ookla/speedtest-cli/script.rpm.sh | sudo bash | ||||
|             sudo dnf install -y speedtest | ||||
|         elif command -v yum &> /dev/null; then | ||||
|             sudo yum install -y curl | ||||
|             curl -s https://packagecloud.io/install/repositories/ookla/speedtest-cli/script.rpm.sh | sudo bash | ||||
|             sudo yum install -y speedtest | ||||
|         elif command -v apt-get &> /dev/null; then | ||||
|             sudo apt-get update && sudo apt-get install -y curl | ||||
|             curl -s https://packagecloud.io/install/repositories/ookla/speedtest-cli/script.deb.sh | sudo bash | ||||
|             sudo apt-get install -y speedtest | ||||
|         elif command -v apt &> /dev/null; then | ||||
|             sudo apt update && sudo apt install -y curl | ||||
|             curl -s https://packagecloud.io/install/repositories/ookla/speedtest-cli/script.deb.sh | sudo bash | ||||
|             sudo apt install -y speedtest | ||||
|         else | ||||
|             echo "Error: Package manager not found. You may need to install Speedtest manually." | ||||
|             return 1 | ||||
|         fi | ||||
|     fi | ||||
| 
 | ||||
|     # Run Speedtest | ||||
|     speedtest | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| show_usage() { | ||||
|     echo "x-ui control menu usages: " | ||||
|     echo "------------------------------------------" | ||||
|     echo -e "x-ui              - Enter control menu" | ||||
|     echo -e "x-ui start        - Start x-ui " | ||||
|     echo -e "x-ui stop         - Stop  x-ui " | ||||
|     echo -e "x-ui restart      - Restart x-ui " | ||||
|     echo -e "x-ui status       - Show x-ui status" | ||||
|     echo -e "x-ui enable       - Enable x-ui on system startup" | ||||
|     echo -e "x-ui disable      - Disable x-ui on system startup" | ||||
|     echo -e "x-ui log          - Check x-ui logs" | ||||
|     echo -e "x-ui update       - Update x-ui " | ||||
|     echo -e "x-ui install      - Install x-ui " | ||||
|     echo -e "x-ui uninstall    - Uninstall x-ui " | ||||
|     echo "------------------------------------------" | ||||
| } | ||||
| 
 | ||||
| show_menu() { | ||||
|     echo -e " | ||||
|   ${green}3X-ui Panel Management Script${plain} | ||||
|   ${green}0.${plain} Exit Script | ||||
| ———————————————— | ||||
|   ${green}1.${plain} Install x-ui | ||||
|   ${green}2.${plain} Update x-ui | ||||
|   ${green}3.${plain} Uninstall x-ui | ||||
| ———————————————— | ||||
|   ${green}4.${plain} Reset Username & Password & Secret Token | ||||
|   ${green}5.${plain} Reset Panel Settings | ||||
|   ${green}6.${plain} Change Panel Port | ||||
|   ${green}7.${plain} View Current Panel Settings | ||||
| ———————————————— | ||||
|   ${green}8.${plain} Start x-ui | ||||
|   ${green}9.${plain} Stop x-ui | ||||
|   ${green}10.${plain} Restart x-ui | ||||
|   ${green}11.${plain} Check x-ui Status | ||||
|   ${green}12.${plain} Check x-ui Logs | ||||
| ———————————————— | ||||
|   ${green}13.${plain} Enable x-ui On System Startup | ||||
|   ${green}14.${plain} Disable x-ui On System Startup | ||||
| ———————————————— | ||||
|   ${green}15.${plain} Enable BBR  | ||||
|   ${green}16.${plain} Apply for an SSL Certificate | ||||
|   ${green}17.${plain} Update Geo Files | ||||
|   ${green}18.${plain} Active Firewall and open ports | ||||
|   ${green}19.${plain} Install WARP | ||||
|   ${green}20.${plain} Speedtest by Ookla | ||||
|  " | ||||
|     show_status | ||||
|     echo && read -p "Please enter your selection [0-20]: " num | ||||
| 
 | ||||
|     case "${num}" in | ||||
|     0) | ||||
|         exit 0 | ||||
|         ;; | ||||
|     1) | ||||
|         check_uninstall && install | ||||
|         ;; | ||||
|     2) | ||||
|         check_install && update | ||||
|         ;; | ||||
|     3) | ||||
|         check_install && uninstall | ||||
|         ;; | ||||
|     4) | ||||
|         check_install && reset_user | ||||
|         ;; | ||||
|     5) | ||||
|         check_install && reset_config | ||||
|         ;; | ||||
|     6) | ||||
|         check_install && set_port | ||||
|         ;; | ||||
|     7) | ||||
|         check_install && check_config | ||||
|         ;; | ||||
|     8) | ||||
|         check_install && start | ||||
|         ;; | ||||
|     9) | ||||
|         check_install && stop | ||||
|         ;; | ||||
|     10) | ||||
|         check_install && restart | ||||
|         ;; | ||||
|     11) | ||||
|         check_install && status | ||||
|         ;; | ||||
|     12) | ||||
|         check_install && show_log | ||||
|         ;; | ||||
|     13) | ||||
|         check_install && enable | ||||
|         ;; | ||||
|     14) | ||||
|         check_install && disable | ||||
|         ;; | ||||
|     15) | ||||
|         enable_bbr | ||||
|         ;; | ||||
|     16) | ||||
|         ssl_cert_issue | ||||
|         ;; | ||||
|     17) | ||||
|         update_geo | ||||
|         ;; | ||||
|     18) | ||||
|         open_ports | ||||
|         ;; | ||||
|     19) | ||||
|         warp_fixchatgpt | ||||
|         ;; | ||||
| 	20) | ||||
|         run_speedtest | ||||
|         ;; | ||||
|     *) | ||||
|         LOGE "Please enter the correct number [0-20]" | ||||
|         ;; | ||||
|     esac | ||||
| } | ||||
| 
 | ||||
| if [[ $# > 0 ]]; then | ||||
|     case $1 in | ||||
|     "start") | ||||
|         check_install 0 && start 0 | ||||
|         ;; | ||||
|     "stop") | ||||
|         check_install 0 && stop 0 | ||||
|         ;; | ||||
|     "restart") | ||||
|         check_install 0 && restart 0 | ||||
|         ;; | ||||
|     "status") | ||||
|         check_install 0 && status 0 | ||||
|         ;; | ||||
|     "enable") | ||||
|         check_install 0 && enable 0 | ||||
|         ;; | ||||
|     "disable") | ||||
|         check_install 0 && disable 0 | ||||
|         ;; | ||||
|     "log") | ||||
|         check_install 0 && show_log 0 | ||||
|         ;; | ||||
|     "update") | ||||
|         check_install 0 && update 0 | ||||
|         ;; | ||||
|     "install") | ||||
|         check_uninstall 0 && install 0 | ||||
|         ;; | ||||
|     "uninstall") | ||||
|         check_install 0 && uninstall 0 | ||||
|         ;; | ||||
|     *) show_usage ;; | ||||
|     esac | ||||
| else | ||||
|     show_menu | ||||
| fi | ||||
		Loading…
	
		Reference in a new issue
	
	 Peyman
						Peyman