mirror of
https://github.com/0xJacky/nginx-ui.git
synced 2025-05-11 02:15:48 +02:00
49 lines
1.3 KiB
Go
49 lines
1.3 KiB
Go
package server
|
|
|
|
import (
|
|
"github.com/0xJacky/Nginx-UI/server/internal/analytic"
|
|
"github.com/0xJacky/Nginx-UI/server/internal/cert"
|
|
"github.com/0xJacky/Nginx-UI/server/internal/logger"
|
|
"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) {
|
|
defer logger.Sync()
|
|
// 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")
|
|
}
|