nginx-ui/server/server.go
2023-05-06 21:09:22 +08:00

48 lines
1.2 KiB
Go

package server
import (
"github.com/0xJacky/Nginx-UI/logger"
"github.com/0xJacky/Nginx-UI/server/internal/analytic"
"github.com/0xJacky/Nginx-UI/server/internal/cert"
"github.com/0xJacky/Nginx-UI/server/internal/nginx"
"github.com/0xJacky/Nginx-UI/server/model"
"github.com/0xJacky/Nginx-UI/server/query"
"github.com/0xJacky/Nginx-UI/server/router"
"github.com/0xJacky/Nginx-UI/server/settings"
"github.com/go-co-op/gocron"
"github.com/jpillora/overseer"
"log"
"mime"
"net/http"
"time"
)
func Program(state overseer.State) {
// Hack: fix wrong Content Type of .js file on some OS platforms
// See https://github.com/golang/go/issues/32350
_ = mime.AddExtensionType(".js", "text/javascript; charset=utf-8")
logger.Info("Nginx config dir path: " + nginx.GetConfPath())
if "" != settings.ServerSettings.JwtSecret {
db := model.Init()
query.Init(db)
}
s := gocron.NewScheduler(time.UTC)
job, err := s.Every(30).Minute().SingletonMode().Do(cert.AutoObtain)
if err != nil {
logger.Fatalf("AutoCert Job: %v, Err: %v\n", job, err)
}
s.StartAsync()
go analytic.RecordServerAnalytic()
err = http.Serve(state.Listener, router.InitRouter())
if err != nil {
log.Fatalln(err)
}
logger.Info("Server exiting")
}