mirror of
				https://github.com/MHSanaei/3x-ui.git
				synced 2025-10-26 10:04:41 +00:00 
			
		
		
		
	Update sub.go
This commit is contained in:
		
							parent
							
								
									590567bfa0
								
							
						
					
					
						commit
						c7ec62def1
					
				
					 1 changed files with 77 additions and 1 deletions
				
			
		
							
								
								
									
										78
									
								
								sub/sub.go
									
									
									
									
									
								
							
							
						
						
									
										78
									
								
								sub/sub.go
									
									
									
									
									
								
							|  | @ -3,11 +3,14 @@ package sub | ||||||
| import ( | import ( | ||||||
| 	"context" | 	"context" | ||||||
| 	"crypto/tls" | 	"crypto/tls" | ||||||
|  | 	"embed" | ||||||
|  | 	"html/template" | ||||||
| 	"io" | 	"io" | ||||||
|  | 	"io/fs" | ||||||
| 	"net" | 	"net" | ||||||
| 	"net/http" | 	"net/http" | ||||||
|  | 	"os" | ||||||
| 	"strconv" | 	"strconv" | ||||||
| 
 |  | ||||||
| 	"x-ui/config" | 	"x-ui/config" | ||||||
| 	"x-ui/logger" | 	"x-ui/logger" | ||||||
| 	"x-ui/util/common" | 	"x-ui/util/common" | ||||||
|  | @ -15,9 +18,13 @@ import ( | ||||||
| 	"x-ui/web/network" | 	"x-ui/web/network" | ||||||
| 	"x-ui/web/service" | 	"x-ui/web/service" | ||||||
| 
 | 
 | ||||||
|  | 	"github.com/gin-contrib/gzip" | ||||||
| 	"github.com/gin-gonic/gin" | 	"github.com/gin-gonic/gin" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
|  | //go:embed html/*
 | ||||||
|  | var htmlFS embed.FS | ||||||
|  | 
 | ||||||
| type Server struct { | type Server struct { | ||||||
| 	httpServer *http.Server | 	httpServer *http.Server | ||||||
| 	listener   net.Listener | 	listener   net.Listener | ||||||
|  | @ -37,6 +44,48 @@ func NewServer() *Server { | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | func (s *Server) getHtmlFiles() ([]string, error) { | ||||||
|  | 	files := make([]string, 0) | ||||||
|  | 	dir, _ := os.Getwd() | ||||||
|  | 	err := fs.WalkDir(os.DirFS(dir), "sub/html", func(path string, d fs.DirEntry, err error) error { | ||||||
|  | 		if err != nil { | ||||||
|  | 			return err | ||||||
|  | 		} | ||||||
|  | 		if d.IsDir() { | ||||||
|  | 			return nil | ||||||
|  | 		} | ||||||
|  | 		files = append(files, path) | ||||||
|  | 		return nil | ||||||
|  | 	}) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return nil, err | ||||||
|  | 	} | ||||||
|  | 	return files, nil | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | func (s *Server) getHtmlTemplate(funcMap template.FuncMap) (*template.Template, error) { | ||||||
|  | 	t := template.New("").Funcs(funcMap) | ||||||
|  | 	err := fs.WalkDir(htmlFS, "html", func(path string, d fs.DirEntry, err error) error { | ||||||
|  | 		if err != nil { | ||||||
|  | 			return err | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 		if d.IsDir() { | ||||||
|  | 			newT, err := t.ParseFS(htmlFS, path+"/*.html") | ||||||
|  | 			if err != nil { | ||||||
|  | 				// ignore
 | ||||||
|  | 				return nil | ||||||
|  | 			} | ||||||
|  | 			t = newT | ||||||
|  | 		} | ||||||
|  | 		return nil | ||||||
|  | 	}) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return nil, err | ||||||
|  | 	} | ||||||
|  | 	return t, nil | ||||||
|  | } | ||||||
|  | 
 | ||||||
| func (s *Server) initRouter() (*gin.Engine, error) { | func (s *Server) initRouter() (*gin.Engine, error) { | ||||||
| 	if config.IsDebug() { | 	if config.IsDebug() { | ||||||
| 		gin.SetMode(gin.DebugMode) | 		gin.SetMode(gin.DebugMode) | ||||||
|  | @ -48,6 +97,33 @@ func (s *Server) initRouter() (*gin.Engine, error) { | ||||||
| 
 | 
 | ||||||
| 	engine := gin.Default() | 	engine := gin.Default() | ||||||
| 
 | 
 | ||||||
|  | 	basePath, err := s.settingService.GetBasePath() | ||||||
|  | 	if err != nil { | ||||||
|  | 		return nil, err | ||||||
|  | 	} | ||||||
|  | 	engine.Use(gzip.Gzip(gzip.DefaultCompression, gzip.WithExcludedPaths([]string{basePath + "panel/API/"}))) | ||||||
|  | 
 | ||||||
|  | 	engine.Use(func(c *gin.Context) { | ||||||
|  | 		c.Set("base_path", basePath) | ||||||
|  | 	}) | ||||||
|  | 
 | ||||||
|  | 	// set static files and template
 | ||||||
|  | 	if config.IsDebug() { | ||||||
|  | 		// for development
 | ||||||
|  | 		files, err := s.getHtmlFiles() | ||||||
|  | 		if err != nil { | ||||||
|  | 			return nil, err | ||||||
|  | 		} | ||||||
|  | 		engine.LoadHTMLFiles(files...) | ||||||
|  | 	} else { | ||||||
|  | 		// for production
 | ||||||
|  | 		template, err := s.getHtmlTemplate(engine.FuncMap) | ||||||
|  | 		if err != nil { | ||||||
|  | 			return nil, err | ||||||
|  | 		} | ||||||
|  | 		engine.SetHTMLTemplate(template) | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
| 	subDomain, err := s.settingService.GetSubDomain() | 	subDomain, err := s.settingService.GetSubDomain() | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return nil, err | 		return nil, err | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue
	
	 Hassan Dashtizadeh
						Hassan Dashtizadeh