mirror of
https://gitee.com/dromara/mayfly-go
synced 2025-11-04 00:10:25 +08:00
127 lines
3.3 KiB
Go
127 lines
3.3 KiB
Go
package starter
|
|
|
|
import (
|
|
"context"
|
|
"errors"
|
|
"io/fs"
|
|
"mayfly-go/initialize"
|
|
"mayfly-go/internal/pkg/config"
|
|
"mayfly-go/pkg/i18n"
|
|
"mayfly-go/pkg/logx"
|
|
"mayfly-go/pkg/middleware"
|
|
"mayfly-go/pkg/req"
|
|
"mayfly-go/static"
|
|
"net/http"
|
|
"time"
|
|
|
|
sysapp "mayfly-go/internal/sys/application"
|
|
|
|
"github.com/gin-gonic/gin"
|
|
)
|
|
|
|
func runWebServer(ctx context.Context) {
|
|
// 设置gin日志输出器
|
|
logOut := logx.GetConfig().GetLogOut()
|
|
gin.DefaultErrorWriter = logOut
|
|
gin.DefaultWriter = logOut
|
|
|
|
// 权限处理器
|
|
req.UseBeforeHandlerInterceptor(req.PermissionHandler)
|
|
// 日志处理器
|
|
req.UseAfterHandlerInterceptor(req.LogHandler)
|
|
// 设置日志保存函数
|
|
req.SetSaveLogFunc(sysapp.GetSyslogApp().SaveFromReq)
|
|
|
|
// jwt配置
|
|
jwtConf := config.Conf.Jwt
|
|
req.SetJwtConf(req.JwtConf{
|
|
Key: jwtConf.Key,
|
|
ExpireTime: jwtConf.ExpireTime,
|
|
RefreshTokenExpireTime: jwtConf.RefreshTokenExpireTime,
|
|
})
|
|
|
|
// i18n配置
|
|
i18n.SetLang(config.Conf.Server.Lang)
|
|
|
|
// server配置
|
|
serverConfig := config.Conf.Server
|
|
gin.SetMode(serverConfig.Model)
|
|
|
|
var router = gin.New()
|
|
router.MaxMultipartMemory = 8 << 20
|
|
// 初始化接口路由
|
|
initialize.InitRouter(router, initialize.RouterConfig{ContextPath: serverConfig.ContextPath})
|
|
// 设置静态资源
|
|
setStatic(serverConfig.ContextPath, router)
|
|
// 是否允许跨域
|
|
if serverConfig.Cors {
|
|
router.Use(middleware.Cors())
|
|
}
|
|
|
|
srv := http.Server{
|
|
Addr: config.Conf.Server.GetPort(),
|
|
// 注册路由
|
|
Handler: router,
|
|
}
|
|
|
|
go func() {
|
|
<-ctx.Done()
|
|
logx.Info("Shutdown HTTP Server ...")
|
|
timeout, cancel := context.WithTimeout(context.Background(), 5*time.Second)
|
|
defer cancel()
|
|
err := srv.Shutdown(timeout)
|
|
if err != nil {
|
|
logx.Errorf("failed to Shutdown HTTP Server: %v", err)
|
|
}
|
|
|
|
initialize.Terminate()
|
|
}()
|
|
|
|
confSrv := config.Conf.Server
|
|
logx.Infof("Listening and serving HTTP on %s", srv.Addr+confSrv.ContextPath)
|
|
var err error
|
|
if confSrv.Tls != nil && confSrv.Tls.Enable {
|
|
err = srv.ListenAndServeTLS(confSrv.Tls.CertFile, confSrv.Tls.KeyFile)
|
|
} else {
|
|
err = srv.ListenAndServe()
|
|
}
|
|
if errors.Is(err, http.ErrServerClosed) {
|
|
logx.Info("HTTP Server Shutdown")
|
|
} else if err != nil {
|
|
logx.Errorf("Failed to Start HTTP Server: %v", err)
|
|
}
|
|
}
|
|
|
|
func setStatic(contextPath string, router *gin.Engine) {
|
|
// 使用embed打包静态资源至二进制文件中
|
|
fsys, _ := fs.Sub(static.Static, "static")
|
|
fileServer := http.FileServer(http.FS(fsys))
|
|
handler := WrapStaticHandler(http.StripPrefix(contextPath, fileServer))
|
|
|
|
router.GET(contextPath+"/", handler)
|
|
router.GET(contextPath+"/favicon.ico", handler)
|
|
router.GET(contextPath+"/config.js", handler)
|
|
// 所有/assets/**开头的都是静态资源文件
|
|
router.GET(contextPath+"/assets/*file", handler)
|
|
|
|
// 设置静态资源
|
|
if staticConfs := config.Conf.Server.Static; staticConfs != nil {
|
|
for _, scs := range *staticConfs {
|
|
router.StaticFS(scs.RelativePath, http.Dir(scs.Root))
|
|
}
|
|
}
|
|
// 设置静态文件
|
|
if staticFileConfs := config.Conf.Server.StaticFile; staticFileConfs != nil {
|
|
for _, sfs := range *staticFileConfs {
|
|
router.StaticFile(sfs.RelativePath, sfs.Filepath)
|
|
}
|
|
}
|
|
}
|
|
|
|
func WrapStaticHandler(h http.Handler) gin.HandlerFunc {
|
|
return func(c *gin.Context) {
|
|
c.Writer.Header().Set("Cache-Control", `public, max-age=31536000`)
|
|
h.ServeHTTP(c.Writer, c.Request)
|
|
}
|
|
}
|