mirror of
				https://github.com/MHSanaei/3x-ui.git
				synced 2025-10-26 18:14:50 +00:00 
			
		
		
		
	Compare commits
	
		
			13 commits
		
	
	
		
			e818cccfe3
			...
			2626491ccd
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 2626491ccd | ||
|   | f60682a6b7 | ||
|   | 50bd7a8040 | ||
|   | 7465768ff7 | ||
|   | edd8b12988 | ||
|   | 5b00a52c65 | ||
|   | 151f1173a1 | ||
|   | e262132b9d | ||
|   | ca0a7aeb5a | ||
|   | 7447cec17e | ||
|   | 0ffd27c0aa | ||
|   | 054cb1dea0 | ||
|   | 3757ae0b11 | 
					 56 changed files with 259 additions and 232 deletions
				
			
		|  | @ -7,11 +7,13 @@ | |||
|   </picture> | ||||
| </p> | ||||
| 
 | ||||
| [](https://github.com/MHSanaei/3x-ui/releases) | ||||
| [](https://github.com/MHSanaei/3x-ui/actions) | ||||
| [](#) | ||||
| [](https://github.com/MHSanaei/3x-ui/releases/latest) | ||||
| [](https://www.gnu.org/licenses/gpl-3.0.en.html) | ||||
| [](https://github.com/MHSanaei/3x-ui/releases) | ||||
| [](https://github.com/MHSanaei/3x-ui/actions) | ||||
| [](#) | ||||
| [](https://github.com/MHSanaei/3x-ui/releases/latest) | ||||
| [](https://www.gnu.org/licenses/gpl-3.0.en.html) | ||||
| [](https://pkg.go.dev/github.com/mhsanaei/3x-ui/v2) | ||||
| [](https://goreportcard.com/report/github.com/mhsanaei/3x-ui/v2) | ||||
| 
 | ||||
| **3X-UI** — لوحة تحكم متقدمة مفتوحة المصدر تعتمد على الويب مصممة لإدارة خادم Xray-core. توفر واجهة سهلة الاستخدام لتكوين ومراقبة بروتوكولات VPN والوكيل المختلفة. | ||||
| 
 | ||||
|  |  | |||
|  | @ -7,11 +7,13 @@ | |||
|   </picture> | ||||
| </p> | ||||
| 
 | ||||
| [](https://github.com/MHSanaei/3x-ui/releases) | ||||
| [](https://github.com/MHSanaei/3x-ui/actions) | ||||
| [](#) | ||||
| [](https://github.com/MHSanaei/3x-ui/releases/latest) | ||||
| [](https://www.gnu.org/licenses/gpl-3.0.en.html) | ||||
| [](https://github.com/MHSanaei/3x-ui/releases) | ||||
| [](https://github.com/MHSanaei/3x-ui/actions) | ||||
| [](#) | ||||
| [](https://github.com/MHSanaei/3x-ui/releases/latest) | ||||
| [](https://www.gnu.org/licenses/gpl-3.0.en.html) | ||||
| [](https://pkg.go.dev/github.com/mhsanaei/3x-ui/v2) | ||||
| [](https://goreportcard.com/report/github.com/mhsanaei/3x-ui/v2) | ||||
| 
 | ||||
| **3X-UI** — panel de control avanzado basado en web de código abierto diseñado para gestionar el servidor Xray-core. Ofrece una interfaz fácil de usar para configurar y monitorear varios protocolos VPN y proxy. | ||||
| 
 | ||||
|  |  | |||
|  | @ -7,11 +7,13 @@ | |||
|   </picture> | ||||
| </p> | ||||
| 
 | ||||
| [](https://github.com/MHSanaei/3x-ui/releases) | ||||
| [](https://github.com/MHSanaei/3x-ui/actions) | ||||
| [](#) | ||||
| [](https://github.com/MHSanaei/3x-ui/releases/latest) | ||||
| [](https://www.gnu.org/licenses/gpl-3.0.en.html) | ||||
| [](https://github.com/MHSanaei/3x-ui/releases) | ||||
| [](https://github.com/MHSanaei/3x-ui/actions) | ||||
| [](#) | ||||
| [](https://github.com/MHSanaei/3x-ui/releases/latest) | ||||
| [](https://www.gnu.org/licenses/gpl-3.0.en.html) | ||||
| [](https://pkg.go.dev/github.com/mhsanaei/3x-ui/v2) | ||||
| [](https://goreportcard.com/report/github.com/mhsanaei/3x-ui/v2) | ||||
| 
 | ||||
| **3X-UI** — یک پنل کنترل پیشرفته مبتنی بر وب با کد باز که برای مدیریت سرور Xray-core طراحی شده است. این پنل یک رابط کاربری آسان برای پیکربندی و نظارت بر پروتکلهای مختلف VPN و پراکسی ارائه میدهد. | ||||
| 
 | ||||
|  |  | |||
							
								
								
									
										12
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								README.md
									
									
									
									
									
								
							|  | @ -7,11 +7,13 @@ | |||
|   </picture> | ||||
| </p> | ||||
| 
 | ||||
| [](https://github.com/MHSanaei/3x-ui/releases) | ||||
| [](https://github.com/MHSanaei/3x-ui/actions) | ||||
| [](#) | ||||
| [](https://github.com/MHSanaei/3x-ui/releases/latest) | ||||
| [](https://www.gnu.org/licenses/gpl-3.0.en.html) | ||||
| [](https://github.com/MHSanaei/3x-ui/releases) | ||||
| [](https://github.com/MHSanaei/3x-ui/actions) | ||||
| [](#) | ||||
| [](https://github.com/MHSanaei/3x-ui/releases/latest) | ||||
| [](https://www.gnu.org/licenses/gpl-3.0.en.html) | ||||
| [](https://pkg.go.dev/github.com/mhsanaei/3x-ui/v2) | ||||
| [](https://goreportcard.com/report/github.com/mhsanaei/3x-ui/v2) | ||||
| 
 | ||||
| **3X-UI** — advanced, open-source web-based control panel designed for managing Xray-core server. It offers a user-friendly interface for configuring and monitoring various VPN and proxy protocols. | ||||
| 
 | ||||
|  |  | |||
|  | @ -7,11 +7,13 @@ | |||
|   </picture> | ||||
| </p> | ||||
| 
 | ||||
| [](https://github.com/MHSanaei/3x-ui/releases) | ||||
| [](https://github.com/MHSanaei/3x-ui/actions) | ||||
| [](#) | ||||
| [](https://github.com/MHSanaei/3x-ui/releases/latest) | ||||
| [](https://www.gnu.org/licenses/gpl-3.0.en.html) | ||||
| [](https://github.com/MHSanaei/3x-ui/releases) | ||||
| [](https://github.com/MHSanaei/3x-ui/actions) | ||||
| [](#) | ||||
| [](https://github.com/MHSanaei/3x-ui/releases/latest) | ||||
| [](https://www.gnu.org/licenses/gpl-3.0.en.html) | ||||
| [](https://pkg.go.dev/github.com/mhsanaei/3x-ui/v2) | ||||
| [](https://goreportcard.com/report/github.com/mhsanaei/3x-ui/v2) | ||||
| 
 | ||||
| **3X-UI** — продвинутая панель управления с открытым исходным кодом на основе веб-интерфейса, разработанная для управления сервером Xray-core. Предоставляет удобный интерфейс для настройки и мониторинга различных VPN и прокси-протоколов. | ||||
| 
 | ||||
|  |  | |||
|  | @ -7,11 +7,13 @@ | |||
|   </picture> | ||||
| </p> | ||||
| 
 | ||||
| [](https://github.com/MHSanaei/3x-ui/releases) | ||||
| [](https://github.com/MHSanaei/3x-ui/actions) | ||||
| [](#) | ||||
| [](https://github.com/MHSanaei/3x-ui/releases/latest) | ||||
| [](https://www.gnu.org/licenses/gpl-3.0.en.html) | ||||
| [](https://github.com/MHSanaei/3x-ui/releases) | ||||
| [](https://github.com/MHSanaei/3x-ui/actions) | ||||
| [](#) | ||||
| [](https://github.com/MHSanaei/3x-ui/releases/latest) | ||||
| [](https://www.gnu.org/licenses/gpl-3.0.en.html) | ||||
| [](https://pkg.go.dev/github.com/mhsanaei/3x-ui/v2) | ||||
| [](https://goreportcard.com/report/github.com/mhsanaei/3x-ui/v2) | ||||
| 
 | ||||
| **3X-UI** — 一个基于网页的高级开源控制面板,专为管理 Xray-core 服务器而设计。它提供了用户友好的界面,用于配置和监控各种 VPN 和代理协议。 | ||||
| 
 | ||||
|  |  | |||
|  | @ -1 +1 @@ | |||
| 2.8.1 | ||||
| 2.8.2 | ||||
|  | @ -9,10 +9,10 @@ import ( | |||
| 	"path" | ||||
| 	"slices" | ||||
| 
 | ||||
| 	"x-ui/config" | ||||
| 	"x-ui/database/model" | ||||
| 	"x-ui/util/crypto" | ||||
| 	"x-ui/xray" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/config" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/database/model" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/util/crypto" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/xray" | ||||
| 
 | ||||
| 	"gorm.io/driver/sqlite" | ||||
| 	"gorm.io/gorm" | ||||
|  | @ -142,6 +142,9 @@ func InitDB(dbPath string) error { | |||
| 	} | ||||
| 
 | ||||
| 	isUsersEmpty, err := isTableEmpty("users") | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 
 | ||||
| 	if err := initUser(); err != nil { | ||||
| 		return err | ||||
|  |  | |||
|  | @ -3,8 +3,8 @@ package model | |||
| import ( | ||||
| 	"fmt" | ||||
| 
 | ||||
| 	"x-ui/util/json_util" | ||||
| 	"x-ui/xray" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/util/json_util" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/xray" | ||||
| ) | ||||
| 
 | ||||
| type Protocol string | ||||
|  |  | |||
							
								
								
									
										2
									
								
								go.mod
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								go.mod
									
									
									
									
									
								
							|  | @ -1,4 +1,4 @@ | |||
| module x-ui | ||||
| module github.com/mhsanaei/3x-ui/v2 | ||||
| 
 | ||||
| go 1.25.1 | ||||
| 
 | ||||
|  |  | |||
							
								
								
									
										16
									
								
								main.go
									
									
									
									
									
								
							
							
						
						
									
										16
									
								
								main.go
									
									
									
									
									
								
							|  | @ -9,14 +9,14 @@ import ( | |||
| 	"syscall" | ||||
| 	_ "unsafe" | ||||
| 
 | ||||
| 	"x-ui/config" | ||||
| 	"x-ui/database" | ||||
| 	"x-ui/logger" | ||||
| 	"x-ui/sub" | ||||
| 	"x-ui/util/crypto" | ||||
| 	"x-ui/web" | ||||
| 	"x-ui/web/global" | ||||
| 	"x-ui/web/service" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/config" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/database" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/logger" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/sub" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/util/crypto" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/web" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/web/global" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/web/service" | ||||
| 
 | ||||
| 	"github.com/joho/godotenv" | ||||
| 	"github.com/op/go-logging" | ||||
|  |  | |||
							
								
								
									
										14
									
								
								sub/sub.go
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								sub/sub.go
									
									
									
									
									
								
							|  | @ -13,13 +13,13 @@ import ( | |||
| 	"strconv" | ||||
| 	"strings" | ||||
| 
 | ||||
| 	"x-ui/logger" | ||||
| 	"x-ui/util/common" | ||||
| 	webpkg "x-ui/web" | ||||
| 	"x-ui/web/locale" | ||||
| 	"x-ui/web/middleware" | ||||
| 	"x-ui/web/network" | ||||
| 	"x-ui/web/service" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/logger" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/util/common" | ||||
| 	webpkg "github.com/mhsanaei/3x-ui/v2/web" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/web/locale" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/web/middleware" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/web/network" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/web/service" | ||||
| 
 | ||||
| 	"github.com/gin-gonic/gin" | ||||
| ) | ||||
|  |  | |||
|  | @ -4,7 +4,8 @@ import ( | |||
| 	"encoding/base64" | ||||
| 	"fmt" | ||||
| 	"strings" | ||||
| 	"x-ui/config" | ||||
| 
 | ||||
| 	"github.com/mhsanaei/3x-ui/v2/config" | ||||
| 
 | ||||
| 	"github.com/gin-gonic/gin" | ||||
| ) | ||||
|  |  | |||
|  | @ -6,12 +6,12 @@ import ( | |||
| 	"fmt" | ||||
| 	"strings" | ||||
| 
 | ||||
| 	"x-ui/database/model" | ||||
| 	"x-ui/logger" | ||||
| 	"x-ui/util/json_util" | ||||
| 	"x-ui/util/random" | ||||
| 	"x-ui/web/service" | ||||
| 	"x-ui/xray" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/database/model" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/logger" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/util/json_util" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/util/random" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/web/service" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/xray" | ||||
| ) | ||||
| 
 | ||||
| //go:embed default.json
 | ||||
|  |  | |||
|  | @ -11,13 +11,13 @@ import ( | |||
| 	"github.com/gin-gonic/gin" | ||||
| 	"github.com/goccy/go-json" | ||||
| 
 | ||||
| 	"x-ui/database" | ||||
| 	"x-ui/database/model" | ||||
| 	"x-ui/logger" | ||||
| 	"x-ui/util/common" | ||||
| 	"x-ui/util/random" | ||||
| 	"x-ui/web/service" | ||||
| 	"x-ui/xray" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/database" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/database/model" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/logger" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/util/common" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/util/random" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/web/service" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/xray" | ||||
| ) | ||||
| 
 | ||||
| type SubService struct { | ||||
|  |  | |||
|  | @ -4,7 +4,7 @@ import ( | |||
| 	"errors" | ||||
| 	"fmt" | ||||
| 
 | ||||
| 	"x-ui/logger" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/logger" | ||||
| ) | ||||
| 
 | ||||
| func NewErrorf(format string, a ...any) error { | ||||
|  |  | |||
|  | @ -1,7 +1,7 @@ | |||
| package controller | ||||
| 
 | ||||
| import ( | ||||
| 	"x-ui/web/service" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/web/service" | ||||
| 
 | ||||
| 	"github.com/gin-gonic/gin" | ||||
| ) | ||||
|  |  | |||
|  | @ -3,9 +3,9 @@ package controller | |||
| import ( | ||||
| 	"net/http" | ||||
| 
 | ||||
| 	"x-ui/logger" | ||||
| 	"x-ui/web/locale" | ||||
| 	"x-ui/web/session" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/logger" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/web/locale" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/web/session" | ||||
| 
 | ||||
| 	"github.com/gin-gonic/gin" | ||||
| ) | ||||
|  |  | |||
|  | @ -5,10 +5,10 @@ import ( | |||
| 	"fmt" | ||||
| 	"strconv" | ||||
| 
 | ||||
| 	"x-ui/database/model" | ||||
| 	"x-ui/web/middleware" | ||||
| 	"x-ui/web/service" | ||||
| 	"x-ui/web/session" | ||||
| 
 | ||||
| 	"github.com/mhsanaei/3x-ui/v2/database/model" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/web/service" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/web/session" | ||||
| 
 | ||||
| 	"github.com/gin-gonic/gin" | ||||
| ) | ||||
|  | @ -109,8 +109,7 @@ func (a *InboundController) addInbound(c *gin.Context) { | |||
| 		inbound.Tag = fmt.Sprintf("inbound-%v:%v", inbound.Listen, inbound.Port) | ||||
| 	} | ||||
| 
 | ||||
| 	needRestart := false | ||||
| 	inbound, needRestart, err = a.inboundService.AddInbound(inbound) | ||||
| 	inbound, needRestart, err := a.inboundService.AddInbound(inbound) | ||||
| 	if err != nil { | ||||
| 		jsonMsg(c, I18nWeb(c, "somethingWentWrong"), err) | ||||
| 		return | ||||
|  | @ -127,8 +126,7 @@ func (a *InboundController) delInbound(c *gin.Context) { | |||
| 		jsonMsg(c, I18nWeb(c, "pages.inbounds.toasts.inboundDeleteSuccess"), err) | ||||
| 		return | ||||
| 	} | ||||
| 	needRestart := true | ||||
| 	needRestart, err = a.inboundService.DelInbound(id) | ||||
| 	needRestart, err := a.inboundService.DelInbound(id) | ||||
| 	if err != nil { | ||||
| 		jsonMsg(c, I18nWeb(c, "somethingWentWrong"), err) | ||||
| 		return | ||||
|  | @ -153,8 +151,7 @@ func (a *InboundController) updateInbound(c *gin.Context) { | |||
| 		jsonMsg(c, I18nWeb(c, "pages.inbounds.toasts.inboundUpdateSuccess"), err) | ||||
| 		return | ||||
| 	} | ||||
| 	needRestart := true | ||||
| 	inbound, needRestart, err = a.inboundService.UpdateInbound(inbound) | ||||
| 	inbound, needRestart, err := a.inboundService.UpdateInbound(inbound) | ||||
| 	if err != nil { | ||||
| 		jsonMsg(c, I18nWeb(c, "somethingWentWrong"), err) | ||||
| 		return | ||||
|  | @ -196,9 +193,7 @@ func (a *InboundController) addInboundClient(c *gin.Context) { | |||
| 		return | ||||
| 	} | ||||
| 
 | ||||
| 	needRestart := true | ||||
| 
 | ||||
| 	needRestart, err = a.inboundService.AddInboundClient(data) | ||||
| 	needRestart, err := a.inboundService.AddInboundClient(data) | ||||
| 	if err != nil { | ||||
| 		jsonMsg(c, I18nWeb(c, "somethingWentWrong"), err) | ||||
| 		return | ||||
|  | @ -217,9 +212,7 @@ func (a *InboundController) delInboundClient(c *gin.Context) { | |||
| 	} | ||||
| 	clientId := c.Param("clientId") | ||||
| 
 | ||||
| 	needRestart := true | ||||
| 
 | ||||
| 	needRestart, err = a.inboundService.DelInboundClient(id, clientId) | ||||
| 	needRestart, err := a.inboundService.DelInboundClient(id, clientId) | ||||
| 	if err != nil { | ||||
| 		jsonMsg(c, I18nWeb(c, "somethingWentWrong"), err) | ||||
| 		return | ||||
|  | @ -240,9 +233,7 @@ func (a *InboundController) updateInboundClient(c *gin.Context) { | |||
| 		return | ||||
| 	} | ||||
| 
 | ||||
| 	needRestart := true | ||||
| 
 | ||||
| 	needRestart, err = a.inboundService.UpdateInboundClient(inbound, clientId) | ||||
| 	needRestart, err := a.inboundService.UpdateInboundClient(inbound, clientId) | ||||
| 	if err != nil { | ||||
| 		jsonMsg(c, I18nWeb(c, "somethingWentWrong"), err) | ||||
| 		return | ||||
|  |  | |||
|  | @ -5,18 +5,18 @@ import ( | |||
| 	"text/template" | ||||
| 	"time" | ||||
| 
 | ||||
| 	"x-ui/logger" | ||||
| 	"x-ui/web/service" | ||||
| 	"x-ui/web/session" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/logger" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/web/service" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/web/session" | ||||
| 
 | ||||
| 	"github.com/gin-contrib/sessions" | ||||
| 	"github.com/gin-gonic/gin" | ||||
| ) | ||||
| 
 | ||||
| type LoginForm struct { | ||||
| 	Username    	string `json:"username" form:"username"` | ||||
| 	Password    	string `json:"password" form:"password"` | ||||
| 	TwoFactorCode	string `json:"twoFactorCode" form:"twoFactorCode"` | ||||
| 	Username      string `json:"username" form:"username"` | ||||
| 	Password      string `json:"password" form:"password"` | ||||
| 	TwoFactorCode string `json:"twoFactorCode" form:"twoFactorCode"` | ||||
| } | ||||
| 
 | ||||
| type IndexController struct { | ||||
|  |  | |||
|  | @ -7,8 +7,8 @@ import ( | |||
| 	"strconv" | ||||
| 	"time" | ||||
| 
 | ||||
| 	"x-ui/web/global" | ||||
| 	"x-ui/web/service" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/web/global" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/web/service" | ||||
| 
 | ||||
| 	"github.com/gin-gonic/gin" | ||||
| ) | ||||
|  |  | |||
|  | @ -4,10 +4,10 @@ import ( | |||
| 	"errors" | ||||
| 	"time" | ||||
| 
 | ||||
| 	"x-ui/util/crypto" | ||||
| 	"x-ui/web/entity" | ||||
| 	"x-ui/web/service" | ||||
| 	"x-ui/web/session" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/util/crypto" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/web/entity" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/web/service" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/web/session" | ||||
| 
 | ||||
| 	"github.com/gin-gonic/gin" | ||||
| ) | ||||
|  |  | |||
|  | @ -5,9 +5,9 @@ import ( | |||
| 	"net/http" | ||||
| 	"strings" | ||||
| 
 | ||||
| 	"x-ui/config" | ||||
| 	"x-ui/logger" | ||||
| 	"x-ui/web/entity" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/config" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/logger" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/web/entity" | ||||
| 
 | ||||
| 	"github.com/gin-gonic/gin" | ||||
| ) | ||||
|  |  | |||
|  | @ -1,7 +1,7 @@ | |||
| package controller | ||||
| 
 | ||||
| import ( | ||||
| 	"x-ui/web/service" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/web/service" | ||||
| 
 | ||||
| 	"github.com/gin-gonic/gin" | ||||
| ) | ||||
|  |  | |||
|  | @ -7,7 +7,7 @@ import ( | |||
| 	"strings" | ||||
| 	"time" | ||||
| 
 | ||||
| 	"x-ui/util/common" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/util/common" | ||||
| ) | ||||
| 
 | ||||
| type Msg struct { | ||||
|  |  | |||
|  | @ -431,12 +431,12 @@ | |||
|       CPU History | ||||
|       <a-select size="small" v-model="cpuHistoryModal.bucket" class="ml-10" style="width: 80px" | ||||
|         @change="fetchCpuHistoryBucket"> | ||||
|         <a-select-option :value="2">2s</a-select-option> | ||||
|         <a-select-option :value="30">30s</a-select-option> | ||||
|         <a-select-option :value="60">1m</a-select-option> | ||||
|         <a-select-option :value="120">2m</a-select-option> | ||||
|         <a-select-option :value="180">3m</a-select-option> | ||||
|         <a-select-option :value="300">5m</a-select-option> | ||||
|         <a-select-option :value="2">2m</a-select-option> | ||||
|         <a-select-option :value="30">30m</a-select-option> | ||||
|         <a-select-option :value="60">1h</a-select-option> | ||||
|         <a-select-option :value="120">2h</a-select-option> | ||||
|         <a-select-option :value="180">3h</a-select-option> | ||||
|         <a-select-option :value="300">5h</a-select-option> | ||||
|       </a-select> | ||||
|     </template> | ||||
|     <div style="padding:16px"> | ||||
|  | @ -1124,4 +1124,4 @@ | |||
|     }, | ||||
|   }); | ||||
| </script> | ||||
| {{ template "page/body_end" .}} | ||||
| {{ template "page/body_end" .}} | ||||
|  |  | |||
|  | @ -3,22 +3,29 @@ | |||
|   :mask-closable="false" :footer="null" :class="themeSwitcher.currentTheme"> | ||||
|   <a-list class="ant-dns-presets-list" bordered :style="{ width: '100%' }"> | ||||
|     <a-list-item v-for="dns in dnsPresetsDatabase" :style="{ padding: '12px 16px' }"> | ||||
|       <a-row justify="space-between" align="middle"> | ||||
|         <a-col :span="12"> | ||||
|           <a-space direction="vertical" size="small"> | ||||
|             <span class="ant-dns-presets-list-name">[[ dns.name ]]</span> | ||||
|             <a-tag :color="dns.family ? 'purple' : 'green'">[[ dns.family ? '{{ i18n "pages.xray.dns.dnsPresetFamily" }}' : 'DNS' ]]</a-tag> | ||||
|           </a-space> | ||||
|         </a-col> | ||||
|         <a-col :span="12" :style="{ textAlign: 'right' }"> | ||||
|           <a-button type="primary" @click="dnsPresetsModal.install(dns.data)">{{ i18n "install" }}</a-button> | ||||
|         </a-col> | ||||
|       </a-row> | ||||
|       <div class="ant-dns-presets-line"> | ||||
|         <a-space direction="horizontal" size="small" align="center"> | ||||
|           <a-tag :color="dns.family ? 'purple' : 'green'">[[ dns.family ? '{{ i18n "pages.xray.dns.dnsPresetFamily" }}' : 'DNS' ]]</a-tag> | ||||
|           <span class="ant-dns-presets-list-name">[[ dns.name ]]</span> | ||||
|         </a-space> | ||||
|         <a-button class="ant-dns-presets-install" type="primary" @click="dnsPresetsModal.install(dns.data)">{{ i18n "install" }}</a-button> | ||||
|       </div> | ||||
|     </a-list-item> | ||||
|   </a-list> | ||||
| </a-modal> | ||||
| 
 | ||||
| <style> | ||||
|   .ant-dns-presets-line { | ||||
|     display: flex; | ||||
|     align-items: center; | ||||
|     gap: 8px; | ||||
|     width: 100%; | ||||
|   } | ||||
| 
 | ||||
|   .ant-dns-presets-install { | ||||
|     margin-left: auto; | ||||
|   } | ||||
| 
 | ||||
|   .dark .ant-dns-presets-list { | ||||
|     border-color: var(--dark-color-stroke) | ||||
|   } | ||||
|  |  | |||
|  | @ -48,7 +48,13 @@ | |||
|             <template #title>{{ i18n "pages.settings.subPath"}}</template> | ||||
|             <template #description>{{ i18n "pages.settings.subPathDesc"}}</template> | ||||
|             <template #control> | ||||
|                 <a-input type="text" v-model="allSetting.subPath"></a-input> | ||||
|                 <a-input | ||||
|                     type="text" | ||||
|                     v-model="allSetting.subPath" | ||||
|                     @input="allSetting.subPath = ((typeof $event === 'string' ? $event : ($event && $event.target ? $event.target.value : '')) || '').replace(/[:*]/g, '')" | ||||
|                     @blur="allSetting.subPath = (p => { p = p || '/'; if (!p.startsWith('/')) p='/' + p; if (!p.endsWith('/')) p += '/'; return p.replace(/\/+/g,'/'); })(allSetting.subPath)" | ||||
|                     placeholder="/sub/" | ||||
|                 ></a-input> | ||||
|             </template> | ||||
|         </a-setting-list-item> | ||||
|         <a-setting-list-item paddings="small"> | ||||
|  | @ -102,4 +108,4 @@ | |||
|         </a-setting-list-item> | ||||
|     </a-collapse-panel> | ||||
| </a-collapse> | ||||
| {{end}} | ||||
| {{end}} | ||||
|  |  | |||
|  | @ -5,7 +5,13 @@ | |||
|             <template #title>{{ i18n "pages.settings.subPath"}}</template> | ||||
|             <template #description>{{ i18n "pages.settings.subPathDesc"}}</template> | ||||
|             <template #control> | ||||
|                 <a-input type="text" v-model="allSetting.subJsonPath"></a-input> | ||||
|                 <a-input | ||||
|                     type="text" | ||||
|                     v-model="allSetting.subJsonPath" | ||||
|                     @input="allSetting.subJsonPath = ((typeof $event === 'string' ? $event : ($event && $event.target ? $event.target.value : '')) || '').replace(/[:*]/g, '')" | ||||
|                     @blur="allSetting.subJsonPath = (p => { p = p || '/'; if (!p.startsWith('/')) p='/' + p; if (!p.endsWith('/')) p += '/'; return p.replace(/\/+/g,'/'); })(allSetting.subJsonPath)" | ||||
|                     placeholder="/json/" | ||||
|                 ></a-input> | ||||
|             </template> | ||||
|         </a-setting-list-item> | ||||
|         <a-setting-list-item paddings="small"> | ||||
|  |  | |||
|  | @ -12,10 +12,10 @@ import ( | |||
| 	"sort" | ||||
| 	"time" | ||||
| 
 | ||||
| 	"x-ui/database" | ||||
| 	"x-ui/database/model" | ||||
| 	"x-ui/logger" | ||||
| 	"x-ui/xray" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/database" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/database/model" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/logger" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/xray" | ||||
| ) | ||||
| 
 | ||||
| type CheckClientIpJob struct { | ||||
|  |  | |||
|  | @ -4,7 +4,7 @@ import ( | |||
| 	"strconv" | ||||
| 	"time" | ||||
| 
 | ||||
| 	"x-ui/web/service" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/web/service" | ||||
| 
 | ||||
| 	"github.com/shirou/gopsutil/v4/cpu" | ||||
| ) | ||||
|  |  | |||
|  | @ -1,7 +1,7 @@ | |||
| package job | ||||
| 
 | ||||
| import ( | ||||
| 	"x-ui/web/service" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/web/service" | ||||
| ) | ||||
| 
 | ||||
| type CheckHashStorageJob struct { | ||||
|  |  | |||
|  | @ -1,8 +1,8 @@ | |||
| package job | ||||
| 
 | ||||
| import ( | ||||
| 	"x-ui/logger" | ||||
| 	"x-ui/web/service" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/logger" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/web/service" | ||||
| ) | ||||
| 
 | ||||
| type CheckXrayRunningJob struct { | ||||
|  |  | |||
|  | @ -5,8 +5,8 @@ import ( | |||
| 	"os" | ||||
| 	"path/filepath" | ||||
| 
 | ||||
| 	"x-ui/logger" | ||||
| 	"x-ui/xray" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/logger" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/xray" | ||||
| ) | ||||
| 
 | ||||
| type ClearLogsJob struct{} | ||||
|  |  | |||
|  | @ -1,8 +1,8 @@ | |||
| package job | ||||
| 
 | ||||
| import ( | ||||
| 	"x-ui/logger" | ||||
| 	"x-ui/web/service" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/logger" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/web/service" | ||||
| ) | ||||
| 
 | ||||
| type Period string | ||||
|  |  | |||
|  | @ -1,7 +1,7 @@ | |||
| package job | ||||
| 
 | ||||
| import ( | ||||
| 	"x-ui/web/service" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/web/service" | ||||
| ) | ||||
| 
 | ||||
| type LoginStatus byte | ||||
|  |  | |||
|  | @ -2,9 +2,10 @@ package job | |||
| 
 | ||||
| import ( | ||||
| 	"encoding/json" | ||||
| 	"x-ui/logger" | ||||
| 	"x-ui/web/service" | ||||
| 	"x-ui/xray" | ||||
| 
 | ||||
| 	"github.com/mhsanaei/3x-ui/v2/logger" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/web/service" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/xray" | ||||
| 
 | ||||
| 	"github.com/valyala/fasthttp" | ||||
| ) | ||||
|  |  | |||
|  | @ -6,7 +6,7 @@ import ( | |||
| 	"os" | ||||
| 	"strings" | ||||
| 
 | ||||
| 	"x-ui/logger" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/logger" | ||||
| 
 | ||||
| 	"github.com/gin-gonic/gin" | ||||
| 	"github.com/nicksnyder/go-i18n/v2/i18n" | ||||
|  | @ -49,10 +49,10 @@ func InitLocalizer(i18nFS embed.FS, settingService SettingService) error { | |||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| func createTemplateData(params []string, seperator ...string) map[string]any { | ||||
| func createTemplateData(params []string, separator ...string) map[string]any { | ||||
| 	var sep string = "==" | ||||
| 	if len(seperator) > 0 { | ||||
| 		sep = seperator[0] | ||||
| 	if len(separator) > 0 { | ||||
| 		sep = separator[0] | ||||
| 	} | ||||
| 
 | ||||
| 	templateData := make(map[string]any) | ||||
|  |  | |||
|  | @ -11,11 +11,11 @@ import ( | |||
| 	"strings" | ||||
| 	"time" | ||||
| 
 | ||||
| 	"x-ui/database" | ||||
| 	"x-ui/database/model" | ||||
| 	"x-ui/logger" | ||||
| 	"x-ui/util/common" | ||||
| 	"x-ui/xray" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/database" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/database/model" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/logger" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/util/common" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/xray" | ||||
| 
 | ||||
| 	"gorm.io/gorm" | ||||
| ) | ||||
|  | @ -1972,7 +1972,6 @@ func (s *InboundService) GetClientTrafficByEmail(email string) (traffic *xray.Cl | |||
| 	if t != nil && client != nil { | ||||
| 		t.Enable = client.Enable | ||||
| 		t.SubId = client.SubID | ||||
| 		t.UUID = client.ID | ||||
| 		return t, nil | ||||
| 	} | ||||
| 	return nil, nil | ||||
|  | @ -2014,7 +2013,6 @@ func (s *InboundService) GetClientTrafficByID(id string) ([]xray.ClientTraffic, | |||
| 		if ct, client, e := s.GetClientByEmail(traffics[i].Email); e == nil && ct != nil && client != nil { | ||||
| 			traffics[i].Enable = client.Enable | ||||
| 			traffics[i].SubId = client.SubID | ||||
| 			traffics[i].UUID = client.ID | ||||
| 		} | ||||
| 	} | ||||
| 	return traffics, err | ||||
|  | @ -2112,6 +2110,9 @@ func (s *InboundService) MigrationRequirements() { | |||
| 	defer func() { | ||||
| 		if err == nil { | ||||
| 			tx.Commit() | ||||
| 			if dbErr := db.Exec(`VACUUM "main"`).Error; dbErr != nil { | ||||
| 				logger.Warningf("VACUUM failed: %v", dbErr) | ||||
| 			} | ||||
| 		} else { | ||||
| 			tx.Rollback() | ||||
| 		} | ||||
|  |  | |||
|  | @ -1,10 +1,10 @@ | |||
| package service | ||||
| 
 | ||||
| import ( | ||||
| 	"x-ui/database" | ||||
| 	"x-ui/database/model" | ||||
| 	"x-ui/logger" | ||||
| 	"x-ui/xray" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/database" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/database/model" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/logger" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/xray" | ||||
| 
 | ||||
| 	"gorm.io/gorm" | ||||
| ) | ||||
|  |  | |||
|  | @ -5,7 +5,7 @@ import ( | |||
| 	"syscall" | ||||
| 	"time" | ||||
| 
 | ||||
| 	"x-ui/logger" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/logger" | ||||
| ) | ||||
| 
 | ||||
| type PanelService struct{} | ||||
|  |  | |||
|  | @ -19,12 +19,12 @@ import ( | |||
| 	"sync" | ||||
| 	"time" | ||||
| 
 | ||||
| 	"x-ui/config" | ||||
| 	"x-ui/database" | ||||
| 	"x-ui/logger" | ||||
| 	"x-ui/util/common" | ||||
| 	"x-ui/util/sys" | ||||
| 	"x-ui/xray" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/config" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/database" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/logger" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/util/common" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/util/sys" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/xray" | ||||
| 
 | ||||
| 	"github.com/google/uuid" | ||||
| 	"github.com/shirou/gopsutil/v4/cpu" | ||||
|  |  | |||
|  | @ -10,14 +10,14 @@ import ( | |||
| 	"strings" | ||||
| 	"time" | ||||
| 
 | ||||
| 	"x-ui/database" | ||||
| 	"x-ui/database/model" | ||||
| 	"x-ui/logger" | ||||
| 	"x-ui/util/common" | ||||
| 	"x-ui/util/random" | ||||
| 	"x-ui/util/reflect_util" | ||||
| 	"x-ui/web/entity" | ||||
| 	"x-ui/xray" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/database" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/database/model" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/logger" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/util/common" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/util/random" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/util/reflect_util" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/web/entity" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/xray" | ||||
| ) | ||||
| 
 | ||||
| //go:embed config.json
 | ||||
|  |  | |||
|  | @ -18,14 +18,14 @@ import ( | |||
| 	"strings" | ||||
| 	"time" | ||||
| 
 | ||||
| 	"x-ui/config" | ||||
| 	"x-ui/database" | ||||
| 	"x-ui/database/model" | ||||
| 	"x-ui/logger" | ||||
| 	"x-ui/util/common" | ||||
| 	"x-ui/web/global" | ||||
| 	"x-ui/web/locale" | ||||
| 	"x-ui/xray" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/config" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/database" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/database/model" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/logger" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/util/common" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/web/global" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/web/locale" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/xray" | ||||
| 
 | ||||
| 	"github.com/google/uuid" | ||||
| 	"github.com/mymmrac/telego" | ||||
|  | @ -856,7 +856,7 @@ func (t *Tgbot) answerCallback(callbackQuery *telego.CallbackQuery, isAdmin bool | |||
| 				if len(dataArray) == 3 { | ||||
| 					days, err := strconv.Atoi(dataArray[2]) | ||||
| 					if err == nil { | ||||
| 						var date int64 = 0 | ||||
| 						var date int64 | ||||
| 						if days > 0 { | ||||
| 							traffic, err := t.inboundService.GetClientTrafficByEmail(email) | ||||
| 							if err != nil { | ||||
|  | @ -960,7 +960,7 @@ func (t *Tgbot) answerCallback(callbackQuery *telego.CallbackQuery, isAdmin bool | |||
| 			case "add_client_reset_exp_c": | ||||
| 				client_ExpiryTime = 0 | ||||
| 				days, _ := strconv.Atoi(dataArray[1]) | ||||
| 				var date int64 = 0 | ||||
| 				var date int64 | ||||
| 				if client_ExpiryTime > 0 { | ||||
| 					if client_ExpiryTime-time.Now().Unix()*1000 < 0 { | ||||
| 						date = -int64(days * 24 * 60 * 60000) | ||||
|  | @ -1581,23 +1581,6 @@ func (t *Tgbot) answerCallback(callbackQuery *telego.CallbackQuery, isAdmin bool | |||
| 		) | ||||
| 		prompt_message := t.I18nBot("tgbot.messages.comment_prompt", "ClientComment=="+client_Comment) | ||||
| 		t.SendMsgToTgbot(chatId, prompt_message, cancel_btn_markup) | ||||
| 	default: | ||||
| 		// dynamic callbacks
 | ||||
| 		if strings.HasPrefix(callbackQuery.Data, "client_sub_links ") { | ||||
| 			email := strings.TrimPrefix(callbackQuery.Data, "client_sub_links ") | ||||
| 			t.sendClientSubLinks(chatId, email) | ||||
| 			return | ||||
| 		} | ||||
| 		if strings.HasPrefix(callbackQuery.Data, "client_individual_links ") { | ||||
| 			email := strings.TrimPrefix(callbackQuery.Data, "client_individual_links ") | ||||
| 			t.sendClientIndividualLinks(chatId, email) | ||||
| 			return | ||||
| 		} | ||||
| 		if strings.HasPrefix(callbackQuery.Data, "client_qr_links ") { | ||||
| 			email := strings.TrimPrefix(callbackQuery.Data, "client_qr_links ") | ||||
| 			t.sendClientQRLinks(chatId, email) | ||||
| 			return | ||||
| 		} | ||||
| 	case "add_client_ch_default_traffic": | ||||
| 		inlineKeyboard := tu.InlineKeyboard( | ||||
| 			tu.InlineKeyboardRow( | ||||
|  | @ -1813,6 +1796,22 @@ func (t *Tgbot) answerCallback(callbackQuery *telego.CallbackQuery, isAdmin bool | |||
| 			t.SendMsgToTgbot(chatId, msg, tu.ReplyKeyboardRemove()) | ||||
| 
 | ||||
| 		} | ||||
| 	default: | ||||
| 		if after, ok := strings.CutPrefix(callbackQuery.Data, "client_sub_links "); ok { | ||||
| 			email := after | ||||
| 			t.sendClientSubLinks(chatId, email) | ||||
| 			return | ||||
| 		} | ||||
| 		if after, ok := strings.CutPrefix(callbackQuery.Data, "client_individual_links "); ok { | ||||
| 			email := after | ||||
| 			t.sendClientIndividualLinks(chatId, email) | ||||
| 			return | ||||
| 		} | ||||
| 		if after, ok := strings.CutPrefix(callbackQuery.Data, "client_qr_links "); ok { | ||||
| 			email := after | ||||
| 			t.sendClientQRLinks(chatId, email) | ||||
| 			return | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
|  |  | |||
|  | @ -3,10 +3,10 @@ package service | |||
| import ( | ||||
| 	"errors" | ||||
| 
 | ||||
| 	"x-ui/database" | ||||
| 	"x-ui/database/model" | ||||
| 	"x-ui/logger" | ||||
| 	"x-ui/util/crypto" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/database" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/database/model" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/logger" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/util/crypto" | ||||
| 
 | ||||
| 	"github.com/xlzd/gotp" | ||||
| 	"gorm.io/gorm" | ||||
|  |  | |||
|  | @ -7,8 +7,9 @@ import ( | |||
| 	"net/http" | ||||
| 	"os" | ||||
| 	"time" | ||||
| 	"x-ui/logger" | ||||
| 	"x-ui/util/common" | ||||
| 
 | ||||
| 	"github.com/mhsanaei/3x-ui/v2/logger" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/util/common" | ||||
| ) | ||||
| 
 | ||||
| type WarpService struct { | ||||
|  |  | |||
|  | @ -6,8 +6,8 @@ import ( | |||
| 	"runtime" | ||||
| 	"sync" | ||||
| 
 | ||||
| 	"x-ui/logger" | ||||
| 	"x-ui/xray" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/logger" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/xray" | ||||
| 
 | ||||
| 	"go.uber.org/atomic" | ||||
| ) | ||||
|  |  | |||
|  | @ -4,8 +4,8 @@ import ( | |||
| 	_ "embed" | ||||
| 	"encoding/json" | ||||
| 
 | ||||
| 	"x-ui/util/common" | ||||
| 	"x-ui/xray" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/util/common" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/xray" | ||||
| ) | ||||
| 
 | ||||
| type XraySettingService struct { | ||||
|  |  | |||
|  | @ -4,7 +4,7 @@ import ( | |||
| 	"encoding/gob" | ||||
| 	"net/http" | ||||
| 
 | ||||
| 	"x-ui/database/model" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/database/model" | ||||
| 
 | ||||
| 	"github.com/gin-contrib/sessions" | ||||
| 	"github.com/gin-gonic/gin" | ||||
|  |  | |||
							
								
								
									
										18
									
								
								web/web.go
									
									
									
									
									
								
							
							
						
						
									
										18
									
								
								web/web.go
									
									
									
									
									
								
							|  | @ -14,15 +14,15 @@ import ( | |||
| 	"strings" | ||||
| 	"time" | ||||
| 
 | ||||
| 	"x-ui/config" | ||||
| 	"x-ui/logger" | ||||
| 	"x-ui/util/common" | ||||
| 	"x-ui/web/controller" | ||||
| 	"x-ui/web/job" | ||||
| 	"x-ui/web/locale" | ||||
| 	"x-ui/web/middleware" | ||||
| 	"x-ui/web/network" | ||||
| 	"x-ui/web/service" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/config" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/logger" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/util/common" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/web/controller" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/web/job" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/web/locale" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/web/middleware" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/web/network" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/web/service" | ||||
| 
 | ||||
| 	"github.com/gin-contrib/gzip" | ||||
| 	"github.com/gin-contrib/sessions" | ||||
|  |  | |||
|  | @ -4,12 +4,12 @@ import ( | |||
| 	"context" | ||||
| 	"encoding/json" | ||||
| 	"fmt" | ||||
| 	"math" | ||||
| 	"regexp" | ||||
| 	"time" | ||||
| 	"math" | ||||
| 
 | ||||
| 	"x-ui/logger" | ||||
| 	"x-ui/util/common" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/logger" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/util/common" | ||||
| 
 | ||||
| 	"github.com/xtls/xray-core/app/proxyman/command" | ||||
| 	statsService "github.com/xtls/xray-core/app/stats/command" | ||||
|  |  | |||
|  | @ -5,7 +5,6 @@ type ClientTraffic struct { | |||
| 	InboundId  int    `json:"inboundId" form:"inboundId"` | ||||
| 	Enable     bool   `json:"enable" form:"enable"` | ||||
| 	Email      string `json:"email" form:"email" gorm:"unique"` | ||||
| 	UUID       string `json:"uuid" form:"uuid" gorm:"unique;type:char(36)"` | ||||
| 	SubId      string `json:"subId" form:"subId" gorm:"-"` | ||||
| 	Up         int64  `json:"up" form:"up"` | ||||
| 	Down       int64  `json:"down" form:"down"` | ||||
|  |  | |||
|  | @ -3,7 +3,7 @@ package xray | |||
| import ( | ||||
| 	"bytes" | ||||
| 
 | ||||
| 	"x-ui/util/json_util" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/util/json_util" | ||||
| ) | ||||
| 
 | ||||
| type Config struct { | ||||
|  |  | |||
|  | @ -3,7 +3,7 @@ package xray | |||
| import ( | ||||
| 	"bytes" | ||||
| 
 | ||||
| 	"x-ui/util/json_util" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/util/json_util" | ||||
| ) | ||||
| 
 | ||||
| type InboundConfig struct { | ||||
|  |  | |||
|  | @ -5,7 +5,7 @@ import ( | |||
| 	"runtime" | ||||
| 	"strings" | ||||
| 
 | ||||
| 	"x-ui/logger" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/logger" | ||||
| ) | ||||
| 
 | ||||
| func NewLogWriter() *LogWriter { | ||||
|  |  | |||
|  | @ -13,9 +13,9 @@ import ( | |||
| 	"syscall" | ||||
| 	"time" | ||||
| 
 | ||||
| 	"x-ui/config" | ||||
| 	"x-ui/logger" | ||||
| 	"x-ui/util/common" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/config" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/logger" | ||||
| 	"github.com/mhsanaei/3x-ui/v2/util/common" | ||||
| ) | ||||
| 
 | ||||
| func GetBinaryName() string { | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue