1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374 |
- package router
- import (
- "github.com/gin-gonic/gin"
- log "github.com/go-admin-team/go-admin-core/logger"
- "github.com/go-admin-team/go-admin-core/sdk"
- // "github.com/go-admin-team/go-admin-core/sdk/pkg"
- common "go-admin/common/middleware"
- "os"
- jwt "github.com/go-admin-team/go-admin-core/sdk/pkg/jwtauth"
- )
- var (
- routerNoCheckRole = make([]func(*gin.RouterGroup), 0)
- routerCheckRole = make([]func(v1 *gin.RouterGroup, authMiddleware *jwt.GinJWTMiddleware), 0)
- )
- // InitRouter 路由初始化
- func InitRouter() {
- var r *gin.Engine
- h := sdk.Runtime.GetEngine()
- if h == nil {
- h = gin.New()
- sdk.Runtime.SetEngine(h)
- }
- switch t := h.(type) {
- case *gin.Engine:
- r = t
- default:
- log.Fatal("not support other engine")
- os.Exit(-1)
- }
- // the jwt middleware
- authMiddleware, err := common.AuthInit()
- if err != nil {
- log.Fatalf("JWT Init Error, %s", err.Error())
- }
- // 注册业务路由
- InitBusinessRouter(r, authMiddleware)
- }
- func InitBusinessRouter(r *gin.Engine, authMiddleware *jwt.GinJWTMiddleware) *gin.Engine {
- // 无需认证的路由
- noCheckRoleRouter(r)
- // 需要认证的路由
- checkRoleRouter(r, authMiddleware)
- return r
- }
- // noCheckRoleRouter 无需认证的路由
- func noCheckRoleRouter(r *gin.Engine) {
- // 可根据业务需求来设置接口版本
- v := r.Group("/api/v1")
- for _, f := range routerNoCheckRole {
- f(v)
- }
- }
- // checkRoleRouter 需要认证的路由
- func checkRoleRouter(r *gin.Engine, authMiddleware *jwt.GinJWTMiddleware) {
- // 可根据业务需求来设置接口版本
- v := r.Group("/api/v1")
- for _, f := range routerCheckRole {
- f(v, authMiddleware)
- }
- }
|