package server import ( "crypto/tls" "encoding/gob" "fmt" "net" "net/http" "os" "path" "github.com/1Panel-dev/1Panel/core/constant" "github.com/1Panel-dev/1Panel/core/global" "github.com/1Panel-dev/1Panel/core/i18n" "github.com/1Panel-dev/1Panel/core/init/cron" "github.com/1Panel-dev/1Panel/core/init/db" "github.com/1Panel-dev/1Panel/core/init/hook" "github.com/1Panel-dev/1Panel/core/init/log" "github.com/1Panel-dev/1Panel/core/init/migration" "github.com/1Panel-dev/1Panel/core/init/router" "github.com/1Panel-dev/1Panel/core/init/session" "github.com/1Panel-dev/1Panel/core/init/session/psession" "github.com/1Panel-dev/1Panel/core/init/validator" "github.com/1Panel-dev/1Panel/core/init/viper" "github.com/gin-gonic/gin" ) func Start() { viper.Init() i18n.Init() log.Init() db.Init() migration.Init() validator.Init() gob.Register(psession.SessionUser{}) cron.Init() session.Init() gin.SetMode("debug") InitOthers() hook.Init() rootRouter := router.Routers() tcpItem := "tcp4" if global.CONF.System.Ipv6 == constant.StatusEnable { tcpItem = "tcp" global.CONF.System.BindAddress = fmt.Sprintf("[%s]", global.CONF.System.BindAddress) } server := &http.Server{ Addr: global.CONF.System.BindAddress + ":" + global.CONF.System.Port, Handler: rootRouter, } ln, err := net.Listen(tcpItem, server.Addr) if err != nil { panic(err) } type tcpKeepAliveListener struct { *net.TCPListener } if global.CONF.System.SSL == constant.StatusEnable { certPath := path.Join(global.CONF.System.BaseDir, "1panel/secret/server.crt") keyPath := path.Join(global.CONF.System.BaseDir, "1panel/secret/server.key") certificate, err := os.ReadFile(certPath) if err != nil { panic(err) } key, err := os.ReadFile(keyPath) if err != nil { panic(err) } cert, err := tls.X509KeyPair(certificate, key) if err != nil { panic(err) } server.TLSConfig = &tls.Config{ GetCertificate: func(info *tls.ClientHelloInfo) (*tls.Certificate, error) { return &cert, nil }, } global.LOG.Infof("listen at https://%s:%s [%s]", global.CONF.System.BindAddress, global.CONF.System.Port, tcpItem) if err := server.ServeTLS(tcpKeepAliveListener{ln.(*net.TCPListener)}, "", ""); err != nil { panic(err) } } else { global.LOG.Infof("listen at http://%s:%s [%s]", global.CONF.System.BindAddress, global.CONF.System.Port, tcpItem) if err := server.Serve(tcpKeepAliveListener{ln.(*net.TCPListener)}); err != nil { panic(err) } } }