index.go 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  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. var permissions []string
  28. if userInfo != nil {
  29. userId := userEntity.Id
  30. delete(userInfo, "user_password")
  31. userInfo["roles"] = make([]string, 0)
  32. //获取用户角色信息
  33. allRoles, err := auth_service.GetRoleList()
  34. if err == nil {
  35. roles, err := user_service.GetAdminRole(userId, allRoles)
  36. if err == nil {
  37. name := make([]string, len(roles))
  38. roleIds := make([]uint, len(roles))
  39. for k, v := range roles {
  40. name[k] = v.Name
  41. roleIds[k] = v.Id
  42. }
  43. userInfo["roles"] = roles
  44. isSuperAdmin := false
  45. //获取无需验证权限的用户id
  46. for _, v := range service.NotCheckAuthAdminIds {
  47. if gconv.Uint64(v) == userId {
  48. isSuperAdmin = true
  49. break
  50. }
  51. }
  52. if isSuperAdmin {
  53. permissions = []string{"*/*/*"}
  54. } else {
  55. permissions, err = user_service.GetPermissions(roleIds)
  56. }
  57. rolesList = name
  58. } else {
  59. g.Log().Error(err)
  60. }
  61. } else {
  62. g.Log().Error(err)
  63. }
  64. }
  65. result := g.Map{
  66. "user": userInfo,
  67. "roles": rolesList,
  68. "permissions": permissions,
  69. }
  70. response.SusJson(true, r, "ok", result)
  71. }
  72. // @Summary 获取后台菜单
  73. // @Description 获取后台菜单
  74. // @Tags 公共
  75. // @Success 0 {object} response.Response "{"code": 200, "data": [...]}"
  76. // @Router /system/index/getRouters [get]
  77. // @Security
  78. func (c *Index) GetRouters(r *ghttp.Request) {
  79. //获取用户信息
  80. userEntity := user_service.GetLoginAdminInfo(r)
  81. //菜单列表
  82. var menuList g.List
  83. isSuperAdmin := false
  84. if userEntity != nil {
  85. userId := userEntity.Id
  86. //获取无需验证权限的用户id
  87. for _, v := range service.NotCheckAuthAdminIds {
  88. if gconv.Uint64(v) == userId {
  89. isSuperAdmin = true
  90. break
  91. }
  92. }
  93. //获取用户角色信息
  94. allRoles, err := auth_service.GetRoleList()
  95. if err == nil {
  96. roles, err := user_service.GetAdminRole(userId, allRoles)
  97. if err == nil {
  98. name := make([]string, len(roles))
  99. roleIds := make([]uint, len(roles))
  100. for k, v := range roles {
  101. name[k] = v.Name
  102. roleIds[k] = v.Id
  103. }
  104. //获取菜单信息
  105. if isSuperAdmin {
  106. //超管获取所有菜单
  107. menuList, err = user_service.GetAllMenus()
  108. } else {
  109. menuList, err = user_service.GetAdminMenusByRoleIds(roleIds)
  110. }
  111. if err != nil {
  112. g.Log().Error(err)
  113. }
  114. } else {
  115. g.Log().Error(err)
  116. }
  117. } else {
  118. g.Log().Error(err)
  119. }
  120. }
  121. if menuList == nil {
  122. menuList = g.List{}
  123. }
  124. response.SusJson(true, r, "ok", menuList)
  125. }