| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128 | 
							- package entity
 
- import (
 
- 	"crypto/tls"
 
- 	"net"
 
- 	"strings"
 
- 	"time"
 
- 	"x-ui/util/common"
 
- )
 
- type Msg struct {
 
- 	Success bool        `json:"success"`
 
- 	Msg     string      `json:"msg"`
 
- 	Obj     interface{} `json:"obj"`
 
- }
 
- type AllSetting struct {
 
- 	WebListen        string `json:"webListen" form:"webListen"`
 
- 	WebDomain        string `json:"webDomain" form:"webDomain"`
 
- 	WebPort          int    `json:"webPort" form:"webPort"`
 
- 	WebCertFile      string `json:"webCertFile" form:"webCertFile"`
 
- 	WebKeyFile       string `json:"webKeyFile" form:"webKeyFile"`
 
- 	WebBasePath      string `json:"webBasePath" form:"webBasePath"`
 
- 	SessionMaxAge    int    `json:"sessionMaxAge" form:"sessionMaxAge"`
 
- 	PageSize         int    `json:"pageSize" form:"pageSize"`
 
- 	ExpireDiff       int    `json:"expireDiff" form:"expireDiff"`
 
- 	TrafficDiff      int    `json:"trafficDiff" form:"trafficDiff"`
 
- 	RemarkModel      string `json:"remarkModel" form:"remarkModel"`
 
- 	TgBotEnable      bool   `json:"tgBotEnable" form:"tgBotEnable"`
 
- 	TgBotToken       string `json:"tgBotToken" form:"tgBotToken"`
 
- 	TgBotProxy       string `json:"tgBotProxy" form:"tgBotProxy"`
 
- 	TgBotChatId      string `json:"tgBotChatId" form:"tgBotChatId"`
 
- 	TgRunTime        string `json:"tgRunTime" form:"tgRunTime"`
 
- 	TgBotBackup      bool   `json:"tgBotBackup" form:"tgBotBackup"`
 
- 	TgBotLoginNotify bool   `json:"tgBotLoginNotify" form:"tgBotLoginNotify"`
 
- 	TgCpu            int    `json:"tgCpu" form:"tgCpu"`
 
- 	TgLang           string `json:"tgLang" form:"tgLang"`
 
- 	TimeLocation     string `json:"timeLocation" form:"timeLocation"`
 
- 	SecretEnable     bool   `json:"secretEnable" form:"secretEnable"`
 
- 	SubEnable        bool   `json:"subEnable" form:"subEnable"`
 
- 	SubListen        string `json:"subListen" form:"subListen"`
 
- 	SubPort          int    `json:"subPort" form:"subPort"`
 
- 	SubPath          string `json:"subPath" form:"subPath"`
 
- 	SubDomain        string `json:"subDomain" form:"subDomain"`
 
- 	SubCertFile      string `json:"subCertFile" form:"subCertFile"`
 
- 	SubKeyFile       string `json:"subKeyFile" form:"subKeyFile"`
 
- 	SubUpdates       int    `json:"subUpdates" form:"subUpdates"`
 
- 	SubEncrypt       bool   `json:"subEncrypt" form:"subEncrypt"`
 
- 	SubShowInfo      bool   `json:"subShowInfo" form:"subShowInfo"`
 
- 	SubURI           string `json:"subURI" form:"subURI"`
 
- 	SubJsonPath      string `json:"subJsonPath" form:"subJsonPath"`
 
- 	SubJsonURI       string `json:"subJsonURI" form:"subJsonURI"`
 
- 	SubJsonFragment  string `json:"subJsonFragment" form:"subJsonFragment"`
 
- 	SubJsonNoise     string `json:"subJsonNoise" form:"subJsonNoise"`
 
- 	SubJsonMux       string `json:"subJsonMux" form:"subJsonMux"`
 
- 	SubJsonRules     string `json:"subJsonRules" form:"subJsonRules"`
 
- 	Datepicker       string `json:"datepicker" form:"datepicker"`
 
- }
 
- func (s *AllSetting) CheckValid() error {
 
- 	if s.WebListen != "" {
 
- 		ip := net.ParseIP(s.WebListen)
 
- 		if ip == nil {
 
- 			return common.NewError("web listen is not valid ip:", s.WebListen)
 
- 		}
 
- 	}
 
- 	if s.SubListen != "" {
 
- 		ip := net.ParseIP(s.SubListen)
 
- 		if ip == nil {
 
- 			return common.NewError("Sub listen is not valid ip:", s.SubListen)
 
- 		}
 
- 	}
 
- 	if s.WebPort <= 0 || s.WebPort > 65535 {
 
- 		return common.NewError("web port is not a valid port:", s.WebPort)
 
- 	}
 
- 	if s.SubPort <= 0 || s.SubPort > 65535 {
 
- 		return common.NewError("Sub port is not a valid port:", s.SubPort)
 
- 	}
 
- 	if (s.SubPort == s.WebPort) && (s.WebListen == s.SubListen) {
 
- 		return common.NewError("Sub and Web could not use same ip:port, ", s.SubListen, ":", s.SubPort, " & ", s.WebListen, ":", s.WebPort)
 
- 	}
 
- 	if s.WebCertFile != "" || s.WebKeyFile != "" {
 
- 		_, err := tls.LoadX509KeyPair(s.WebCertFile, s.WebKeyFile)
 
- 		if err != nil {
 
- 			return common.NewErrorf("cert file <%v> or key file <%v> invalid: %v", s.WebCertFile, s.WebKeyFile, err)
 
- 		}
 
- 	}
 
- 	if s.SubCertFile != "" || s.SubKeyFile != "" {
 
- 		_, err := tls.LoadX509KeyPair(s.SubCertFile, s.SubKeyFile)
 
- 		if err != nil {
 
- 			return common.NewErrorf("cert file <%v> or key file <%v> invalid: %v", s.SubCertFile, s.SubKeyFile, err)
 
- 		}
 
- 	}
 
- 	if !strings.HasPrefix(s.WebBasePath, "/") {
 
- 		s.WebBasePath = "/" + s.WebBasePath
 
- 	}
 
- 	if !strings.HasSuffix(s.WebBasePath, "/") {
 
- 		s.WebBasePath += "/"
 
- 	}
 
- 	if !strings.HasPrefix(s.SubPath, "/") {
 
- 		s.SubPath = "/" + s.SubPath
 
- 	}
 
- 	if !strings.HasSuffix(s.SubPath, "/") {
 
- 		s.SubPath += "/"
 
- 	}
 
- 	if !strings.HasPrefix(s.SubJsonPath, "/") {
 
- 		s.SubJsonPath = "/" + s.SubJsonPath
 
- 	}
 
- 	if !strings.HasSuffix(s.SubJsonPath, "/") {
 
- 		s.SubJsonPath += "/"
 
- 	}
 
- 	_, err := time.LoadLocation(s.TimeLocation)
 
- 	if err != nil {
 
- 		return common.NewError("time location not exist:", s.TimeLocation)
 
- 	}
 
- 	return nil
 
- }
 
 
  |