mirror of
				https://github.com/MHSanaei/3x-ui.git
				synced 2025-10-26 10:04:41 +00:00 
			
		
		
		
	fix: check default credentials during a fresh installation
	
		
			
	
		
	
	
		
	
		
			Some checks are pending
		
		
	
	
		
			
				
	
				Build and Release 3X-UI / build (386) (push) Waiting to run
				
			
		
			
				
	
				Build and Release 3X-UI / build (amd64) (push) Waiting to run
				
			
		
			
				
	
				Build and Release 3X-UI / build (arm64) (push) Waiting to run
				
			
		
			
				
	
				Build and Release 3X-UI / build (armv5) (push) Waiting to run
				
			
		
			
				
	
				Build and Release 3X-UI / build (armv6) (push) Waiting to run
				
			
		
			
				
	
				Build and Release 3X-UI / build (armv7) (push) Waiting to run
				
			
		
			
				
	
				Build and Release 3X-UI / build (s390x) (push) Waiting to run
				
			
		
		
	
	
				
					
				
			
		
			Some checks are pending
		
		
	
	Build and Release 3X-UI / build (386) (push) Waiting to run
				
			Build and Release 3X-UI / build (amd64) (push) Waiting to run
				
			Build and Release 3X-UI / build (arm64) (push) Waiting to run
				
			Build and Release 3X-UI / build (armv5) (push) Waiting to run
				
			Build and Release 3X-UI / build (armv6) (push) Waiting to run
				
			Build and Release 3X-UI / build (armv7) (push) Waiting to run
				
			Build and Release 3X-UI / build (s390x) (push) Waiting to run
				
			This commit is contained in:
		
							parent
							
								
									63edc63ab0
								
							
						
					
					
						commit
						13cf7271d6
					
				
					 8 changed files with 16 additions and 12 deletions
				
			
		|  | @ -33,7 +33,7 @@ | |||
| 
 | ||||
| لتثبيت المشروع أو تحديثه، نفذ الأمر ده: | ||||
| ```bash | ||||
| bash <(curl -Ls https://raw.githubusercontent.com/mhsanaei/3x-ui/master/install.sh) | ||||
| bash <(curl -Ls https://raw.githubusercontent.com/MHSanaei/3x-ui/refs/tags/v2.5.8/install.sh) | ||||
| ``` | ||||
| 
 | ||||
| ## تثبيت النسخة القديمة (مش موصى بيها) | ||||
|  |  | |||
|  | @ -32,7 +32,7 @@ | |||
| ## Instalar y Actualizar | ||||
| 
 | ||||
| ``` | ||||
| bash <(curl -Ls https://raw.githubusercontent.com/mhsanaei/3x-ui/master/install.sh) | ||||
| bash <(curl -Ls https://raw.githubusercontent.com/MHSanaei/3x-ui/refs/tags/v2.5.8/install.sh) | ||||
| ``` | ||||
| 
 | ||||
| ## Instalar versión antigua (no recomendamos) | ||||
|  |  | |||
|  | @ -32,7 +32,7 @@ | |||
| ## نصب و ارتقا | ||||
| 
 | ||||
| ``` | ||||
| bash <(curl -Ls https://raw.githubusercontent.com/mhsanaei/3x-ui/master/install.sh) | ||||
| bash <(curl -Ls https://raw.githubusercontent.com/MHSanaei/3x-ui/refs/tags/v2.5.8/install.sh) | ||||
| ``` | ||||
| 
 | ||||
| ## نصب نسخههای قدیمی (توصیه نمیشود) | ||||
|  |  | |||
|  | @ -32,7 +32,7 @@ | |||
| ## Install & Upgrade | ||||
| 
 | ||||
| ``` | ||||
| bash <(curl -Ls https://raw.githubusercontent.com/mhsanaei/3x-ui/master/install.sh) | ||||
| bash <(curl -Ls https://raw.githubusercontent.com/MHSanaei/3x-ui/refs/tags/v2.5.8/install.sh) | ||||
| ``` | ||||
| 
 | ||||
| ## Install legacy Version (we don't recommend) | ||||
|  |  | |||
|  | @ -32,7 +32,7 @@ | |||
| ## Установка и обновление | ||||
| 
 | ||||
| ``` | ||||
| bash <(curl -Ls https://raw.githubusercontent.com/mhsanaei/3x-ui/master/install.sh) | ||||
| bash <(curl -Ls https://raw.githubusercontent.com/MHSanaei/3x-ui/refs/tags/v2.5.8/install.sh) | ||||
| ``` | ||||
| 
 | ||||
| ## Установить старую версию (мы не рекомендуем) | ||||
|  |  | |||
|  | @ -32,7 +32,7 @@ | |||
| ## 安装 & 升级 | ||||
| 
 | ||||
| ``` | ||||
| bash <(curl -Ls https://raw.githubusercontent.com/mhsanaei/3x-ui/master/install.sh) | ||||
| bash <(curl -Ls https://raw.githubusercontent.com/MHSanaei/3x-ui/refs/tags/v2.5.8/install.sh) | ||||
| ``` | ||||
| 
 | ||||
| ## 安装旧版本 (我们不建议) | ||||
|  |  | |||
|  | @ -82,14 +82,13 @@ gen_random_string() { | |||
| } | ||||
| 
 | ||||
| config_after_install() { | ||||
|     local existing_username=$(/usr/local/x-ui/x-ui setting -show true | grep -Eo 'username: .+' | awk '{print $2}') | ||||
|     local existing_password=$(/usr/local/x-ui/x-ui setting -show true | grep -Eo 'password: .+' | awk '{print $2}') | ||||
|     local existing_hasDefaultCredential=$(/usr/local/x-ui/x-ui setting -show true | grep -Eo 'hasDefaultCredential: .+' | awk '{print $2}') | ||||
|     local existing_webBasePath=$(/usr/local/x-ui/x-ui setting -show true | grep -Eo 'webBasePath: .+' | awk '{print $2}') | ||||
|     local existing_port=$(/usr/local/x-ui/x-ui setting -show true | grep -Eo 'port: .+' | awk '{print $2}') | ||||
|     local server_ip=$(curl -s https://api.ipify.org) | ||||
| 
 | ||||
|     if [[ ${#existing_webBasePath} -lt 4 ]]; then | ||||
|         if [[ "$existing_username" == "admin" && "$existing_password" == "admin" ]]; then | ||||
|         if [[ "$existing_hasDefaultCredential" == "true" ]]; then | ||||
|             local config_webBasePath=$(gen_random_string 15) | ||||
|             local config_username=$(gen_random_string 10) | ||||
|             local config_password=$(gen_random_string 10) | ||||
|  | @ -112,7 +111,6 @@ config_after_install() { | |||
|             echo -e "${green}WebBasePath: ${config_webBasePath}${plain}" | ||||
|             echo -e "${green}Access URL: http://${server_ip}:${config_port}/${config_webBasePath}${plain}" | ||||
|             echo -e "###############################################" | ||||
|             echo -e "${yellow}If you forgot your login info, you can type 'x-ui settings' to check${plain}" | ||||
|         else | ||||
|             local config_webBasePath=$(gen_random_string 15) | ||||
|             echo -e "${yellow}WebBasePath is missing or too short. Generating a new one...${plain}" | ||||
|  | @ -121,7 +119,7 @@ config_after_install() { | |||
|             echo -e "${green}Access URL: http://${server_ip}:${existing_port}/${config_webBasePath}${plain}" | ||||
|         fi | ||||
|     else | ||||
|         if [[ "$existing_username" == "admin" && "$existing_password" == "admin" ]]; then | ||||
|         if [[ "$existing_hasDefaultCredential" == "true" ]]; then | ||||
|             local config_username=$(gen_random_string 10) | ||||
|             local config_password=$(gen_random_string 10) | ||||
| 
 | ||||
|  | @ -132,7 +130,6 @@ config_after_install() { | |||
|             echo -e "${green}Username: ${config_username}${plain}" | ||||
|             echo -e "${green}Password: ${config_password}${plain}" | ||||
|             echo -e "###############################################" | ||||
|             echo -e "${yellow}If you forgot your login info, you can type 'x-ui settings' to check${plain}" | ||||
|         else | ||||
|             echo -e "${green}Username, Password, and WebBasePath are properly set. Exiting...${plain}" | ||||
|         fi | ||||
|  |  | |||
							
								
								
									
										7
									
								
								main.go
									
									
									
									
									
								
							
							
						
						
									
										7
									
								
								main.go
									
									
									
									
									
								
							|  | @ -16,6 +16,7 @@ import ( | |||
| 	"x-ui/web" | ||||
| 	"x-ui/web/global" | ||||
| 	"x-ui/web/service" | ||||
| 	"x-ui/util/crypto" | ||||
| 
 | ||||
| 	"github.com/op/go-logging" | ||||
| ) | ||||
|  | @ -161,6 +162,12 @@ func showSetting(show bool) { | |||
| 		} else { | ||||
| 			fmt.Println("Panel is secure with SSL") | ||||
| 		} | ||||
| 
 | ||||
| 		hasDefaultCredential := func() bool { | ||||
| 			return userModel.Username == "admin" && crypto.CheckPasswordHash(userModel.Password, "admin") | ||||
| 		}() | ||||
| 
 | ||||
| 		fmt.Println("hasDefaultCredential:", hasDefaultCredential) | ||||
| 		fmt.Println("port:", port) | ||||
| 		fmt.Println("webBasePath:", webBasePath) | ||||
| 	} | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue
	
	 Shishkevich D.
						Shishkevich D.