index.go 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. package admin
  2. import (
  3. "gfast/app/service/admin/auth_service"
  4. "gfast/app/service/admin/user_service"
  5. "gfast/library/response"
  6. "gfast/library/service"
  7. "github.com/gogf/gf/frame/g"
  8. "github.com/gogf/gf/net/ghttp"
  9. "github.com/gogf/gf/util/gconv"
  10. )
  11. type Index struct{}
  12. // @Summary 获取登录用户信息
  13. // @Description 获取登录用户信息
  14. // @Tags 公共
  15. // @Success 0 {object} response.Response "{"code": 200, "data": [...]}"
  16. // @Router /system/index/getInfo [get]
  17. // @Security
  18. func (c *Index) GetInfo(r *ghttp.Request) {
  19. //获取用户信息
  20. userEntity, err := user_service.GetCurrentUser(r)
  21. if err != nil {
  22. g.Log().Error(err)
  23. response.FailJson(true, r, "获取当前登录用户信息失败")
  24. }
  25. userInfo := gconv.Map(userEntity)
  26. rolesList := make([]string, 0, 10)
  27. if userInfo != nil {
  28. userId := userEntity.Id
  29. delete(userInfo, "user_password")
  30. userInfo["roles"] = make([]string, 0)
  31. //获取用户角色信息
  32. allRoles, err := auth_service.GetRoleList()
  33. if err == nil {
  34. roles, err := user_service.GetAdminRole(userId, allRoles)
  35. if err == nil {
  36. name := make([]string, len(roles))
  37. roleIds := make([]uint, len(roles))
  38. for k, v := range roles {
  39. name[k] = v.Name
  40. roleIds[k] = v.Id
  41. }
  42. userInfo["roles"] = roles
  43. rolesList = name
  44. } else {
  45. g.Log().Error(err)
  46. }
  47. } else {
  48. g.Log().Error(err)
  49. }
  50. }
  51. result := g.Map{
  52. "user": userInfo,
  53. "roles": rolesList,
  54. "permissions": nil,
  55. }
  56. response.SusJson(true, r, "ok", result)
  57. }
  58. // @Summary 获取后台菜单
  59. // @Description 获取后台菜单
  60. // @Tags 公共
  61. // @Success 0 {object} response.Response "{"code": 200, "data": [...]}"
  62. // @Router /system/index/getRouters [get]
  63. // @Security
  64. func (c *Index) GetRouters(r *ghttp.Request) {
  65. //获取用户信息
  66. userEntity := user_service.GetLoginAdminInfo(r)
  67. //菜单列表
  68. var menuList g.List
  69. isSuperAdmin := false
  70. if userEntity != nil {
  71. userId := userEntity.Id
  72. //获取无需验证权限的用户id
  73. for _, v := range service.NotCheckAuthAdminIds {
  74. if gconv.Uint64(v) == userId {
  75. isSuperAdmin = true
  76. break
  77. }
  78. }
  79. //获取用户角色信息
  80. allRoles, err := auth_service.GetRoleList()
  81. if err == nil {
  82. roles, err := user_service.GetAdminRole(userId, allRoles)
  83. if err == nil {
  84. name := make([]string, len(roles))
  85. roleIds := make([]uint, len(roles))
  86. for k, v := range roles {
  87. name[k] = v.Name
  88. roleIds[k] = v.Id
  89. }
  90. //获取菜单信息
  91. if isSuperAdmin {
  92. //超管获取所有菜单
  93. menuList, err = user_service.GetAllMenus()
  94. } else {
  95. menuList, err = user_service.GetAdminMenusByRoleIds(roleIds)
  96. }
  97. if err != nil {
  98. g.Log().Error(err)
  99. }
  100. } else {
  101. g.Log().Error(err)
  102. }
  103. } else {
  104. g.Log().Error(err)
  105. }
  106. }
  107. if menuList == nil {
  108. menuList = g.List{}
  109. }
  110. response.SusJson(true, r, "ok", menuList)
  111. }