89 lines
2.4 KiB
Go
89 lines
2.4 KiB
Go
package router
|
||
|
||
import (
|
||
"go-admin/app/admin/apis"
|
||
"mime"
|
||
|
||
"github.com/go-admin-team/go-admin-core/sdk/config"
|
||
|
||
"github.com/gin-gonic/gin"
|
||
jwt "github.com/go-admin-team/go-admin-core/sdk/pkg/jwtauth"
|
||
"github.com/go-admin-team/go-admin-core/sdk/pkg/ws"
|
||
ginSwagger "github.com/swaggo/gin-swagger"
|
||
|
||
swaggerfiles "github.com/swaggo/files"
|
||
|
||
"go-admin/common/middleware"
|
||
"go-admin/common/middleware/handler"
|
||
_ "go-admin/docs/admin"
|
||
)
|
||
|
||
func InitSysRouter(r *gin.Engine, authMiddleware *jwt.GinJWTMiddleware) *gin.RouterGroup {
|
||
g := r.Group("")
|
||
sysBaseRouter(g)
|
||
// 静态文件
|
||
sysStaticFileRouter(g)
|
||
// swagger;注意:生产环境可以注释掉
|
||
if config.ApplicationConfig.Mode != "prod" {
|
||
sysSwaggerRouter(g)
|
||
}
|
||
// 需要认证
|
||
sysCheckRoleRouterInit(g, authMiddleware)
|
||
return g
|
||
}
|
||
|
||
func sysBaseRouter(r *gin.RouterGroup) {
|
||
|
||
go ws.WebsocketManager.Start()
|
||
go ws.WebsocketManager.SendService()
|
||
go ws.WebsocketManager.SendAllService()
|
||
|
||
if config.ApplicationConfig.Mode != "prod" {
|
||
r.GET("/", apis.GoAdmin)
|
||
}
|
||
r.GET("/info", handler.Ping)
|
||
}
|
||
|
||
func sysStaticFileRouter(r *gin.RouterGroup) {
|
||
err := mime.AddExtensionType(".js", "application/javascript")
|
||
if err != nil {
|
||
return
|
||
}
|
||
r.Static("/static", "./static")
|
||
if config.ApplicationConfig.Mode != "prod" {
|
||
r.Static("/form-generator", "./static/form-generator")
|
||
}
|
||
}
|
||
|
||
func sysSwaggerRouter(r *gin.RouterGroup) {
|
||
r.GET("/swagger/admin/*any", ginSwagger.WrapHandler(swaggerfiles.NewHandler(), ginSwagger.InstanceName("admin")))
|
||
}
|
||
|
||
func sysCheckRoleRouterInit(r *gin.RouterGroup, authMiddleware *jwt.GinJWTMiddleware) {
|
||
wss := r.Group("").Use(authMiddleware.MiddlewareFunc())
|
||
{
|
||
wss.GET("/ws/:id/:channel", ws.WebsocketManager.WsClient)
|
||
wss.GET("/wslogout/:id/:channel", ws.WebsocketManager.UnWsClient)
|
||
}
|
||
|
||
v1 := r.Group("/api/v1")
|
||
{
|
||
v1.POST("/login", authMiddleware.LoginHandler)
|
||
// Refresh time can be longer than token timeout
|
||
v1.GET("/refresh_token", authMiddleware.RefreshHandler)
|
||
}
|
||
registerBaseRouter(v1, authMiddleware)
|
||
}
|
||
|
||
func registerBaseRouter(v1 *gin.RouterGroup, authMiddleware *jwt.GinJWTMiddleware) {
|
||
api := apis.SysMenu{}
|
||
api2 := apis.SysDept{}
|
||
v1auth := v1.Group("").Use(authMiddleware.MiddlewareFunc()).Use(middleware.AuthCheckRole())
|
||
{
|
||
v1auth.GET("/roleMenuTreeselect/:roleId", api.GetMenuTreeSelect)
|
||
//v1.GET("/menuTreeselect", api.GetMenuTreeSelect)
|
||
v1auth.GET("/roleDeptTreeselect/:roleId", api2.GetDeptTreeRoleSelect)
|
||
v1auth.POST("/logout", handler.LogOut)
|
||
}
|
||
}
|