gin/router/server.go

125 lines
3.2 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-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
"git.zhangdeman.cn/zhangdeman/consts"
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
)
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, option any) *server {
if port < 80 {
panic("port should be greater than 80")
}
return &server{
2025-02-15 22:34:21 +08:00
router: gin.Default(),
docInstance: NewDoc(nil, []*apiDocDefine.ServerItem{
{
Url: fmt.Sprintf("http://127.0.0.1:%d", port),
Description: "测试服务器",
},
}), // TODO : 配置相关信息
port: port,
2025-02-07 18:33:07 +08:00
}
}
type server struct {
2025-02-14 22:30:56 +08:00
router *gin.Engine
port int
docInstance *Doc
2025-02-07 18:33:07 +08:00
}
// Start 启动服务
//
// Author : go_developer@163.com<白茶清欢>
//
// Date : 18:31 2025/2/7
func (s *server) Start() {
if err := s.router.Run(fmt.Sprintf(":%d", s.port)); err != nil {
panic("服务启动监听失败" + err.Error())
}
}
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-14 22:30:56 +08:00
s.docInstance.Add(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
}
}
}
2025-02-15 21:53:21 +08:00
// 注册文档
s.SwaggerUI()
}
// SwaggerUI ...
//
// Author : go_developer@163.com<白茶清欢>
//
// Date : 21:45 2025/2/15
func (s *server) SwaggerUI() {
swaggerInstance := NewSwaggerUI(s.docInstance, SwaggerUIThemeDefault)
2025-02-15 22:34:21 +08:00
s.router.GET("/doc/swagger/*any", func(ctx *gin.Context) {
if ctx.Request.RequestURI == "/doc/swagger/doc.json" {
// 默认swagger, 通过此接口读取文档数据
2025-02-15 21:53:21 +08:00
ctx.JSON(http.StatusOK, swaggerInstance.docInstance.Data())
ctx.Abort()
}
2025-02-15 22:34:21 +08:00
if ctx.Request.RequestURI == "/doc/swagger/openapi.json" {
// knife4go 文档通过此接口读取文档列表
ctx.JSON(http.StatusOK, []map[string]any{
{
"name": "服务文档",
"url": "doc.json",
"swaggerVersion": consts.SwaggerDocVersion3,
},
})
ctx.Abort()
}
}, swaggerInstance.Handler())
2025-01-27 19:46:34 +08:00
}