gin/router/server.go

195 lines
5.1 KiB
Go
Raw Normal View History

2025-01-27 19:46:34 +08:00
// Package router ...
//
// Description : router ...
//
// Author : go_developer@163.com<白茶清欢>
//
2025-02-07 18:33:07 +08:00
// Date : 2025-02-07 18:19
2025-01-27 19:46:34 +08:00
package router
import (
2025-02-07 18:33:07 +08:00
"fmt"
2025-02-16 16:44:57 +08:00
apiDoc "git.zhangdeman.cn/gateway/api-doc"
"git.zhangdeman.cn/zhangdeman/consts"
2025-02-16 17:41:33 +08:00
"git.zhangdeman.cn/zhangdeman/gin/middleware"
2025-02-22 15:00:37 +08:00
"git.zhangdeman.cn/zhangdeman/gin/middleware/request_cors"
2025-02-21 15:16:43 +08:00
"github.com/gin-contrib/pprof"
2025-01-27 19:46:34 +08:00
"net/http"
"strings"
2025-02-14 22:30:56 +08:00
2025-02-15 22:34:21 +08:00
apiDocDefine "git.zhangdeman.cn/gateway/api-doc/define"
2025-02-14 22:30:56 +08:00
"github.com/gin-gonic/gin"
2025-01-27 19:46:34 +08:00
)
func newServerOption(port int, optionList ...SetServerOptionFunc) *serverOption {
option := &serverOption{
swaggerUiTheme: apiDocDefine.SwaggerUIThemeRedocFree,
swaggerBaseUri: "/doc/swagger",
globalMiddlewareList: nil,
disableSwaggerDoc: false,
serverInfo: &apiDocDefine.Info{
Description: "这是一个微服务,提供一些必要的的数据接口功能",
Title: "微服务接口文档",
TermsOfService: "",
Contact: &apiDocDefine.Contact{
Name: "开发人员",
Url: "",
Email: "developer@example.com",
},
License: &apiDocDefine.License{
Name: consts.LicenseApache20,
Url: consts.LicenseUrlTable[consts.LicenseApache20],
},
Version: "0.0.1",
},
serverList: []*apiDocDefine.ServerItem{
{
Url: fmt.Sprintf("http://127.0.0.1:%d", port),
Description: "测试服务器",
Variables: nil,
},
},
}
for _, opt := range optionList {
if nil == opt {
continue
}
opt(option)
}
return option
}
2025-02-07 18:33:07 +08:00
// NewServer server实例
//
// Author : go_developer@163.com<白茶清欢>
//
// Date : 18:20 2025/2/7
func NewServer(port int, optionList ...SetServerOptionFunc) *server {
2025-02-07 18:33:07 +08:00
if port < 80 {
panic("port should be greater than 80")
}
option := newServerOption(port, optionList...)
2025-02-22 15:00:37 +08:00
globalMiddlewareList := make([]gin.HandlerFunc, 0)
if option.enableRequestInit {
2025-02-22 15:45:30 +08:00
// 初始化请求中间件
2025-02-22 15:00:37 +08:00
globalMiddlewareList = append(globalMiddlewareList, middleware.InitRequest())
}
2025-02-22 15:45:30 +08:00
if nil != option.loggerCfg {
// 请求日志记录中间件
globalMiddlewareList = append(globalMiddlewareList, middleware.LogRequest(option.loggerCfg))
}
2025-02-22 15:00:37 +08:00
if option.enableCors {
2025-02-22 15:45:30 +08:00
// 跨域中间件
2025-02-22 15:00:37 +08:00
globalMiddlewareList = append(globalMiddlewareList, request_cors.New(request_cors.Config{
2025-02-16 17:41:33 +08:00
AllowAllOrigins: true,
2025-02-22 15:00:37 +08:00
}))
}
if len(option.globalMiddlewareList) > 0 {
// 自定义全局中间件追加
globalMiddlewareList = append(globalMiddlewareList, option.globalMiddlewareList...)
}
2025-02-22 15:00:37 +08:00
r := gin.Default()
// 注册全局中间件
r.Use(globalMiddlewareList...)
2025-02-21 15:16:43 +08:00
// 启用pprof, 注册相关路由
if option.enablePprof {
pprof.Register(r)
}
2025-02-07 18:33:07 +08:00
return &server{
router: r,
uiInstance: apiDoc.NewSwaggerUI(option.serverInfo, option.serverList, option.swaggerUiTheme),
port: port,
option: option,
2025-02-07 18:33:07 +08:00
}
}
type server struct {
2025-02-16 16:44:57 +08:00
router *gin.Engine
port int
uiInstance *apiDoc.SwaggerUI
option *serverOption
2025-02-07 18:33:07 +08:00
}
// Start 启动服务
//
// Author : go_developer@163.com<白茶清欢>
//
// Date : 18:31 2025/2/7
func (s *server) Start() {
2025-02-18 14:39:29 +08:00
// 注册文档
s.uiInstance.RegisterHandler(s.router, s.option.swaggerBaseUri)
2025-02-07 18:33:07 +08:00
if err := s.router.Run(fmt.Sprintf(":%d", s.port)); err != nil {
panic("服务启动监听失败" + err.Error())
}
}
// Router 对外访问路由实例, 不建议直接用
//
// Author : go_developer@163.com<白茶清欢>
//
// Date : 17:35 2025/2/18
func (s *server) Router() *gin.Engine {
return s.router
}
2025-02-22 16:05:56 +08:00
// Handler404 注册404的处理方法
//
// Author : go_developer@163.com<白茶清欢>
//
// Date : 16:01 2025/2/22
func (s *server) Handler404(f gin.HandlerFunc) {
s.router.NoRoute(f)
}
// SetCustomRouter 自定义路由处理
//
// Author : go_developer@163.com<白茶清欢>
//
// Date : 16:09 2025/2/22
func (s *server) SetCustomRouter(f func(r *gin.Engine)) {
if nil == f {
return
}
f(s.router)
}
2025-01-27 19:46:34 +08:00
// Group 注册接口路由
//
// Author : go_developer@163.com<白茶清欢>
//
// Date : 19:35 2025/1/27
2025-02-07 18:33:07 +08:00
func (s *server) Group(routerPrefix string, middlewareList []gin.HandlerFunc, cList ...any) {
g := s.router.Group(routerPrefix)
2025-01-27 19:46:34 +08:00
g.Use(middlewareList...)
cParser := controller{}
for _, c := range cList {
urlTable := cParser.Parse(c)
for _, itemUriCfg := range urlTable {
2025-02-16 16:44:57 +08:00
_ = s.uiInstance.DocInstance().AddApiFromInAndOut(routerPrefix, itemUriCfg.FormDataType, itemUriCfg.ResultDataType)
method := strings.ToUpper(itemUriCfg.RequestMethod)
2025-01-27 19:46:34 +08:00
switch method {
case http.MethodGet:
2025-02-07 16:10:33 +08:00
g.GET(itemUriCfg.Path, RequestHandler(itemUriCfg))
case http.MethodHead:
g.HEAD(itemUriCfg.Path, RequestHandler(itemUriCfg))
case http.MethodPost:
g.POST(itemUriCfg.Path, RequestHandler(itemUriCfg))
case http.MethodPut:
g.PUT(itemUriCfg.Path, RequestHandler(itemUriCfg))
case http.MethodPatch:
g.PATCH(itemUriCfg.Path, RequestHandler(itemUriCfg))
case http.MethodDelete:
g.DELETE(itemUriCfg.Path, RequestHandler(itemUriCfg))
case http.MethodOptions:
g.OPTIONS(itemUriCfg.Path, RequestHandler(itemUriCfg))
case http.MethodTrace:
2025-02-07 18:33:07 +08:00
panic(`method Trace is not supported`)
2025-02-15 22:34:21 +08:00
default:
panic("method " + itemUriCfg.RequestMethod + " is not support")
2025-01-27 19:46:34 +08:00
}
}
}
}