mirror of
				https://github.com/MHSanaei/3x-ui.git
				synced 2025-10-26 18:14:50 +00:00 
			
		
		
		
	Compare commits
	
		
			1 commit
		
	
	
		
			8327db756f
			...
			1fdc6c80ef
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 1fdc6c80ef | 
					 3 changed files with 60 additions and 53 deletions
				
			
		
							
								
								
									
										24
									
								
								install.sh
									
									
									
									
									
								
							
							
						
						
									
										24
									
								
								install.sh
									
									
									
									
									
								
							|  | @ -156,15 +156,11 @@ install_x-ui() { | |||
|     if [ $# == 0 ]; then | ||||
|         tag_version=$(curl -Ls "https://api.github.com/repos/MHSanaei/3x-ui/releases/latest" | grep '"tag_name":' | sed -E 's/.*"([^"]+)".*/\1/') | ||||
|         if [[ ! -n "$tag_version" ]]; then | ||||
|             echo -e "${yellow}Trying to fetch version with IPv4...${plain}" | ||||
|             tag_version=$(curl -4 -Ls "https://api.github.com/repos/MHSanaei/3x-ui/releases/latest" | grep '"tag_name":' | sed -E 's/.*"([^"]+)".*/\1/') | ||||
|             if [[ ! -n "$tag_version" ]]; then | ||||
|                 echo -e "${red}Failed to fetch x-ui version, it may be due to GitHub API restrictions, please try it later${plain}" | ||||
|                 exit 1 | ||||
|             fi | ||||
|             echo -e "${red}Failed to fetch x-ui version, it may be due to GitHub API restrictions, please try it later${plain}" | ||||
|             exit 1 | ||||
|         fi | ||||
|         echo -e "Got x-ui latest version: ${tag_version}, beginning the installation..." | ||||
|         wget --inet4-only -N -O /usr/local/x-ui-linux-$(arch).tar.gz https://github.com/MHSanaei/3x-ui/releases/download/${tag_version}/x-ui-linux-$(arch).tar.gz | ||||
|         wget -N -O /usr/local/x-ui-linux-$(arch).tar.gz https://github.com/MHSanaei/3x-ui/releases/download/${tag_version}/x-ui-linux-$(arch).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 | ||||
|  | @ -181,17 +177,13 @@ install_x-ui() { | |||
| 
 | ||||
|         url="https://github.com/MHSanaei/3x-ui/releases/download/${tag_version}/x-ui-linux-$(arch).tar.gz" | ||||
|         echo -e "Beginning to install x-ui $1" | ||||
|         wget --inet4-only -N -O /usr/local/x-ui-linux-$(arch).tar.gz ${url} | ||||
|         wget -N -O /usr/local/x-ui-linux-$(arch).tar.gz ${url} | ||||
|         if [[ $? -ne 0 ]]; then | ||||
|             echo -e "${red}Download x-ui $1 failed, please check if the version exists ${plain}" | ||||
|             exit 1 | ||||
|         fi | ||||
|     fi | ||||
|     wget --inet4-only -O /usr/bin/x-ui-temp https://raw.githubusercontent.com/MHSanaei/3x-ui/main/x-ui.sh | ||||
|     if [[ $? -ne 0 ]]; then | ||||
|         echo -e "${red}Failed to download x-ui.sh${plain}" | ||||
|         exit 1 | ||||
|     fi | ||||
|     wget -O /usr/bin/x-ui-temp https://raw.githubusercontent.com/MHSanaei/3x-ui/main/x-ui.sh | ||||
| 
 | ||||
|     # Stop x-ui service and remove old resources | ||||
|     if [[ -e /usr/local/x-ui/ ]]; then | ||||
|  | @ -224,11 +216,7 @@ install_x-ui() { | |||
|     config_after_install | ||||
| 
 | ||||
|     if [[ $release == "alpine" ]]; then | ||||
|         wget --inet4-only -O /etc/init.d/x-ui https://raw.githubusercontent.com/MHSanaei/3x-ui/main/x-ui.rc | ||||
|         if [[ $? -ne 0 ]]; then | ||||
|             echo -e "${red}Failed to download x-ui.rc${plain}" | ||||
|             exit 1 | ||||
|         fi | ||||
|         wget -O /etc/init.d/x-ui https://raw.githubusercontent.com/MHSanaei/3x-ui/main/x-ui.rc | ||||
|         chmod +x /etc/init.d/x-ui | ||||
|         rc-update add x-ui | ||||
|         rc-service x-ui start | ||||
|  |  | |||
|  | @ -108,11 +108,17 @@ | |||
|     el: '#app', | ||||
|     data: { | ||||
|       themeSwitcher, | ||||
|       loadingStates: { fetched: false, spinning: false }, | ||||
|       user: { username: "", password: "", twoFactorCode: "" }, | ||||
|       loadingStates: { | ||||
|         fetched: false, | ||||
|         spinning: false | ||||
|       }, | ||||
|       user: { | ||||
|         username: "", | ||||
|         password: "", | ||||
|         twoFactorCode: "" | ||||
|       }, | ||||
|       twoFactorEnable: false, | ||||
|       lang: "", | ||||
|       animationStarted: false | ||||
|       lang: "" | ||||
|     }, | ||||
|     async mounted() { | ||||
|       this.lang = LanguageManager.getLanguage(); | ||||
|  | @ -121,52 +127,65 @@ | |||
|     methods: { | ||||
|       async login() { | ||||
|         this.loadingStates.spinning = true; | ||||
| 
 | ||||
|         const msg = await HttpUtil.post('/login', this.user); | ||||
| 
 | ||||
|         if (msg.success) { | ||||
|           location.href = basePath + 'panel/'; | ||||
|         } | ||||
| 
 | ||||
|         this.loadingStates.spinning = false; | ||||
|       }, | ||||
|       async getTwoFactorEnable() { | ||||
|         const msg = await HttpUtil.post('/getTwoFactorEnable'); | ||||
| 
 | ||||
|         if (msg.success) { | ||||
|           this.twoFactorEnable = msg.obj; | ||||
|           this.loadingStates.fetched = true; | ||||
|           this.$nextTick(() => { | ||||
|             if (!this.animationStarted) { | ||||
|               this.animationStarted = true; | ||||
|               this.initHeadline(); | ||||
|             } | ||||
|           }); | ||||
| 
 | ||||
|           return msg.obj; | ||||
|         } | ||||
|       }, | ||||
|       initHeadline() { | ||||
|         const animationDelay = 2000; | ||||
|         const headlines = this.$el.querySelectorAll('.headline'); | ||||
|         headlines.forEach((headline) => { | ||||
|           const first = headline.querySelector('.is-visible'); | ||||
|           if (!first) return; | ||||
|           setTimeout(() => this.hideWord(first, animationDelay), animationDelay); | ||||
|         }); | ||||
|       }, | ||||
|       hideWord(word, delay) { | ||||
|         const nextWord = this.takeNext(word); | ||||
|         this.switchWord(word, nextWord); | ||||
|         setTimeout(() => this.hideWord(nextWord, delay), delay); | ||||
|       }, | ||||
|       takeNext(word) { | ||||
|         return word.nextElementSibling || word.parentElement.firstElementChild; | ||||
|       }, | ||||
|       switchWord(oldWord, newWord) { | ||||
|         oldWord.classList.remove('is-visible'); | ||||
|         oldWord.classList.add('is-hidden'); | ||||
|         newWord.classList.remove('is-hidden'); | ||||
|         newWord.classList.add('is-visible'); | ||||
|       } | ||||
|     }, | ||||
|   }); | ||||
| 
 | ||||
|   document.addEventListener("DOMContentLoaded", function () { | ||||
|     var animationDelay = 2000; | ||||
|     initHeadline(); | ||||
| 
 | ||||
|     function initHeadline() { | ||||
|       animateHeadline(document.querySelectorAll('.headline')); | ||||
|     } | ||||
| 
 | ||||
|     function animateHeadline(headlines) { | ||||
|       var duration = animationDelay; | ||||
|       headlines.forEach(function (headline) { | ||||
|         setTimeout(function () { | ||||
|           hideWord(headline.querySelector('.is-visible')); | ||||
|         }, duration); | ||||
|       }); | ||||
|     } | ||||
| 
 | ||||
|     function hideWord(word) { | ||||
|       var nextWord = takeNext(word); | ||||
|       switchWord(word, nextWord); | ||||
|       setTimeout(function () { | ||||
|         hideWord(nextWord); | ||||
|       }, animationDelay); | ||||
|     } | ||||
| 
 | ||||
|     function takeNext(word) { | ||||
|       return word.nextElementSibling ? word.nextElementSibling : word.parentElement.firstElementChild; | ||||
|     } | ||||
| 
 | ||||
|     function switchWord(oldWord, newWord) { | ||||
|       oldWord.classList.remove('is-visible'); | ||||
|       oldWord.classList.add('is-hidden'); | ||||
|       newWord.classList.remove('is-hidden'); | ||||
|       newWord.classList.add('is-visible'); | ||||
|     } | ||||
|   }); | ||||
| 
 | ||||
|   const pm_input_selector = 'input.ant-input, textarea.ant-input'; | ||||
|   const pm_strip_props = [ | ||||
|     'background', | ||||
|  |  | |||
|  | @ -648,7 +648,7 @@ | |||
| "ips" = "🔢 IP-адреса:\r\n{{ .IPs }}\r\n" | ||||
| "serverUpTime" = "⏳ Время работы сервера: {{ .UpTime }} {{ .Unit }}\r\n" | ||||
| "serverLoad" = "📈 Нагрузка сервера: {{ .Load1 }}, {{ .Load2 }}, {{ .Load3 }}\r\n" | ||||
| "serverMemory" = "📋 ОЗУ сервера: {{ .Current }}/{{ .Total }}\r\n" | ||||
| "serverMemory" = "📋 Диск сервера: {{ .Current }}/{{ .Total }}\r\n" | ||||
| "tcpCount" = "🔹 Количество TCP-соединений: {{ .Count }}\r\n" | ||||
| "udpCount" = "🔸 Количество UDP-соединений: {{ .Count }}\r\n" | ||||
| "traffic" = "🚦 Трафик: {{ .Total }} (↑{{ .Upload }},↓{{ .Download }})\r\n" | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue