mirror of
				https://github.com/MHSanaei/3x-ui.git
				synced 2025-10-26 18:14:50 +00:00 
			
		
		
		
	Merge branch 'MHSanaei:main' into main
This commit is contained in:
		
						commit
						2018a7e2f2
					
				
					 7 changed files with 49 additions and 23 deletions
				
			
		|  | @ -1 +1 @@ | |||
| 1.6.0 | ||||
| 1.6.1 | ||||
							
								
								
									
										4
									
								
								go.mod
									
									
									
									
									
								
							
							
						
						
									
										4
									
								
								go.mod
									
									
									
									
									
								
							|  | @ -25,7 +25,7 @@ require ( | |||
| require ( | ||||
| 	github.com/BurntSushi/toml v1.2.1 // indirect | ||||
| 	github.com/andybalholm/brotli v1.0.5 // indirect | ||||
| 	github.com/bytedance/sonic v1.8.9 // indirect | ||||
| 	github.com/bytedance/sonic v1.8.10 // indirect | ||||
| 	github.com/chenzhuoyu/base64x v0.0.0-20221115062448-fe3a3abad311 // indirect | ||||
| 	github.com/fasthttp/router v1.4.19 // indirect | ||||
| 	github.com/gabriel-vasile/mimetype v1.4.2 // indirect | ||||
|  | @ -64,7 +64,7 @@ require ( | |||
| 	golang.org/x/crypto v0.9.0 // indirect | ||||
| 	golang.org/x/net v0.10.0 // indirect | ||||
| 	golang.org/x/sys v0.8.0 // indirect | ||||
| 	google.golang.org/genproto v0.0.0-20230410155749-daa745c078e1 // indirect | ||||
| 	google.golang.org/genproto v0.0.0-20230524185152-1884fd1fac28 // indirect | ||||
| 	google.golang.org/protobuf v1.30.0 // indirect | ||||
| 	gopkg.in/yaml.v3 v3.0.1 // indirect | ||||
| ) | ||||
|  |  | |||
							
								
								
									
										8
									
								
								go.sum
									
									
									
									
									
								
							
							
						
						
									
										8
									
								
								go.sum
									
									
									
									
									
								
							|  | @ -10,8 +10,8 @@ github.com/boj/redistore v0.0.0-20180917114910-cd5dcc76aeff/go.mod h1:+RTT1BOk5P | |||
| github.com/bradfitz/gomemcache v0.0.0-20190913173617-a41fca850d0b/go.mod h1:H0wQNHz2YrLsuXOZozoeDmnHXkNCRmMW0gwFWDfEZDA= | ||||
| github.com/bradleypeabody/gorilla-sessions-memcache v0.0.0-20181103040241-659414f458e1/go.mod h1:dkChI7Tbtx7H1Tj7TqGSZMOeGpMP5gLHtjroHd4agiI= | ||||
| github.com/bytedance/sonic v1.5.0/go.mod h1:ED5hyg4y6t3/9Ku1R6dU/4KyJ48DZ4jPhfY1O2AihPM= | ||||
| github.com/bytedance/sonic v1.8.9 h1:mXB6OoHaI9OrWugkvNxWiuHTy5RCrVfxg2Nn40sf0oc= | ||||
| github.com/bytedance/sonic v1.8.9/go.mod h1:i736AoUSYt75HyZLoJW9ERYxcy6eaN6h4BZXU064P/U= | ||||
| github.com/bytedance/sonic v1.8.10 h1:XFSQg4/rwpQnNWSybNDr8oz6QtQY9uRGfRKDVWVsvP8= | ||||
| github.com/bytedance/sonic v1.8.10/go.mod h1:i736AoUSYt75HyZLoJW9ERYxcy6eaN6h4BZXU064P/U= | ||||
| github.com/chenzhuoyu/base64x v0.0.0-20211019084208-fb5309c8db06/go.mod h1:DH46F32mSOjUmXrMHnKwZdA8wcEefY7UVqBKYGjpdQY= | ||||
| github.com/chenzhuoyu/base64x v0.0.0-20221115062448-fe3a3abad311 h1:qSGYFH7+jGhDF8vLC+iwCD4WpbV1EBDSzWkJODFLams= | ||||
| github.com/chenzhuoyu/base64x v0.0.0-20221115062448-fe3a3abad311/go.mod h1:b583jCggY9gE99b6G5LEC39OIiVsWj+R97kbl5odCEk= | ||||
|  | @ -247,8 +247,8 @@ golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7/go.mod h1:I/5z698sn9Ka8T | |||
| golang.org/x/xerrors v0.0.0-20191011141410-1b5146add898/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= | ||||
| golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= | ||||
| golang.org/x/xerrors v0.0.0-20200804184101-5ec99f83aff1/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= | ||||
| google.golang.org/genproto v0.0.0-20230410155749-daa745c078e1 h1:KpwkzHKEF7B9Zxg18WzOa7djJ+Ha5DzthMyZYQfEn2A= | ||||
| google.golang.org/genproto v0.0.0-20230410155749-daa745c078e1/go.mod h1:nKE/iIaLqn2bQwXBg8f1g2Ylh6r5MN5CmZvuzZCgsCU= | ||||
| google.golang.org/genproto v0.0.0-20230524185152-1884fd1fac28 h1:+55/MuGJORMxCrkAgo2595fMAnN/4rweCuwibbqrvpc= | ||||
| google.golang.org/genproto v0.0.0-20230524185152-1884fd1fac28/go.mod h1:nKE/iIaLqn2bQwXBg8f1g2Ylh6r5MN5CmZvuzZCgsCU= | ||||
| google.golang.org/grpc v1.55.0 h1:3Oj82/tFSCeUrRTg/5E/7d/W5A1tj6Ky1ABAuZuv5ag= | ||||
| google.golang.org/grpc v1.55.0/go.mod h1:iYEXKGkEBhg1PjZQvoYEVPTDkHo1/bjTnfwTeGONTY8= | ||||
| google.golang.org/protobuf v1.26.0-rc.1/go.mod h1:jlhhOSvTdKEhbULTjvd4ARK9grFBp09yW+WbY/TyQbw= | ||||
|  |  | |||
|  | @ -213,6 +213,7 @@ body { | |||
| } | ||||
| 
 | ||||
| .ant-card-dark-box-nohover{ | ||||
|     margin-top: .5rem; | ||||
|     padding: 0 20px 20px !important; | ||||
|     box-shadow: 0 1px 10px -1px rgb(154 175 238 / 0%) !important; | ||||
| } | ||||
|  |  | |||
|  | @ -22,6 +22,23 @@ function sizeFormat(size) { | |||
|     } | ||||
| } | ||||
| 
 | ||||
| function cpuSpeedFormat(speed) { | ||||
|     if (speed > 1000) { | ||||
|         const GHz = speed / 1000; | ||||
|         return GHz.toFixed(2) + " GHz"; | ||||
|     } else { | ||||
|         return speed.toFixed(2) + " MHz"; | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| function cpuCoreFormat(cores) { | ||||
|     if (cores === 1) { | ||||
|         return "1 Core"; | ||||
|     } else { | ||||
|         return cores + " Cores"; | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| function base64(str) { | ||||
|     return Base64.encode(str); | ||||
| } | ||||
|  |  | |||
|  | @ -34,8 +34,8 @@ | |||
|                                                     :stroke-color="status.cpu.color" | ||||
|                                                     :class="themeSwitcher.darkCardClass" | ||||
|                                                     :percent="status.cpu.percent"></a-progress> | ||||
|                                         <div>Cores:  [[ status.cpuCores ]]</div> | ||||
|                                         <div>Logical Procs:  [[ status.logicalProcessors ]]</div> | ||||
|                                         <div>CPU:  [[ cpuCoreFormat(status.cpuCores) ]]</div> | ||||
|                                         <div>Speed:  [[ cpuSpeedFormat(status.cpuSpeedMhz) ]]</div> | ||||
|                                     </a-col> | ||||
|                                     <a-col :span="12" style="text-align: center"> | ||||
|                                         <a-progress type="dashboard" status="normal" | ||||
|  | @ -129,7 +129,7 @@ | |||
|                         <a-card hoverable :class="themeSwitcher.darkCardClass"> | ||||
|                             <a-row> | ||||
|                                 <a-col :span="12"> | ||||
|                                     ipv4: | ||||
|                                     IPv4: | ||||
|                                     <a-tooltip> | ||||
|                                         <template slot="title"> | ||||
|                                             [[ status.publicIP.ipv4 ]] | ||||
|  | @ -138,7 +138,7 @@ | |||
|                                     </a-tooltip> | ||||
|                                 </a-col> | ||||
|                                 <a-col :span="12"> | ||||
|                                     ipv6: | ||||
|                                     IPv6: | ||||
|                                     <a-tooltip> | ||||
|                                         <template slot="title"> | ||||
|                                             [[ status.publicIP.ipv6 ]] | ||||
|  | @ -178,7 +178,7 @@ | |||
|                             <a-row> | ||||
|                                 <a-col :span="12"> | ||||
|                                     <a-icon type="arrow-up"></a-icon> | ||||
|                                     [[ sizeFormat(status.netIO.up) ]] / S | ||||
|                                     [[ sizeFormat(status.netIO.up) ]]/S | ||||
|                                     <a-tooltip> | ||||
|                                         <template slot="title"> | ||||
|                                             {{ i18n "pages.index.upSpeed" }} | ||||
|  | @ -188,7 +188,7 @@ | |||
|                                 </a-col> | ||||
|                                 <a-col :span="12"> | ||||
|                                     <a-icon type="arrow-down"></a-icon> | ||||
|                                     [[ sizeFormat(status.netIO.down) ]] / S | ||||
|                                     [[ sizeFormat(status.netIO.down) ]]/S | ||||
|                                     <a-tooltip> | ||||
|                                         <template slot="title"> | ||||
|                                             {{ i18n "pages.index.downSpeed" }} | ||||
|  | @ -334,6 +334,8 @@ | |||
|     class Status { | ||||
|         constructor(data) { | ||||
|             this.cpu = new CurTotal(0, 0); | ||||
|             this.cpuCores = 0; | ||||
|             this.cpuSpeedMhz = 0; | ||||
|             this.disk = new CurTotal(0, 0); | ||||
|             this.loads = [0, 0, 0]; | ||||
|             this.mem = new CurTotal(0, 0); | ||||
|  | @ -343,8 +345,6 @@ | |||
|             this.swap = new CurTotal(0, 0); | ||||
|             this.tcpCount = 0; | ||||
|             this.udpCount = 0; | ||||
|             this.cpuCores = 0; | ||||
|             this.logicalProcessors = 0; | ||||
|             this.uptime = 0; | ||||
|             this.xray = { state: State.Stop, errorMsg: "", version: "", color: "" }; | ||||
| 
 | ||||
|  | @ -352,6 +352,8 @@ | |||
|                 return; | ||||
|             } | ||||
|             this.cpu = new CurTotal(data.cpu, 100); | ||||
|             this.cpuCores = data.cpuCores; | ||||
|             this.cpuSpeedMhz = data.cpuSpeedMhz; | ||||
|             this.disk = new CurTotal(data.disk.current, data.disk.total); | ||||
|             this.loads = data.loads.map(load => toFixed(load, 2)); | ||||
|             this.mem = new CurTotal(data.mem.current, data.mem.total); | ||||
|  | @ -361,8 +363,6 @@ | |||
|             this.swap = new CurTotal(data.swap.current, data.swap.total); | ||||
|             this.tcpCount = data.tcpCount; | ||||
|             this.udpCount = data.udpCount; | ||||
|             this.cpuCores = data.cpuCores; | ||||
|             this.logicalProcessors = data.logicalProcessors; | ||||
|             this.uptime = data.uptime; | ||||
|             this.xray = data.xray; | ||||
|             switch (this.xray.state) { | ||||
|  |  | |||
|  | @ -41,7 +41,7 @@ type Status struct { | |||
| 	T           time.Time `json:"-"` | ||||
| 	Cpu         float64   `json:"cpu"` | ||||
| 	CpuCores    int       `json:"cpuCores"` | ||||
| 	LogicalProcessors int       `json:"logicalProcessors"` | ||||
| 	CpuSpeedMhz float64   `json:"cpuSpeedMhz"` | ||||
| 	Mem         struct { | ||||
| 		Current uint64 `json:"current"` | ||||
| 		Total   uint64 `json:"total"` | ||||
|  | @ -131,7 +131,15 @@ func (s *ServerService) GetStatus(lastStatus *Status) *Status { | |||
| 		logger.Warning("get cpu cores count failed:", err) | ||||
| 	} | ||||
| 
 | ||||
| 	status.LogicalProcessors = runtime.NumCPU() | ||||
| 	cpuInfos, err := cpu.Info() | ||||
| 	if err != nil { | ||||
| 		logger.Warning("get cpu info failed:", err) | ||||
| 	} else if len(cpuInfos) > 0 { | ||||
| 		cpuInfo := cpuInfos[0] | ||||
| 		status.CpuSpeedMhz = cpuInfo.Mhz // setting CPU speed in MHz
 | ||||
| 	} else { | ||||
| 		logger.Warning("could not find cpu info") | ||||
| 	} | ||||
| 
 | ||||
| 	upTime, err := host.Uptime() | ||||
| 	if err != nil { | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue
	
	 Peyman
						Peyman