sys_menu.go 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  1. package service
  2. import (
  3. "errors"
  4. "gin-vue-admin/global"
  5. "gin-vue-admin/model"
  6. "gin-vue-admin/model/request"
  7. )
  8. // @title GetMenuTree
  9. // @description 获取动态菜单树
  10. // @auth (2020/04/05 20:22)
  11. // @param authorityId string
  12. // @return err error
  13. // @return menus []model.SysMenu
  14. func GetMenuTree(authorityId string) (err error, menus []model.SysMenu) {
  15. //sql := "SELECT authority_menu.created_at,authority_menu.updated_at,authority_menu.deleted_at,authority_menu.menu_level,authority_menu.parent_id,authority_menu.path,authority_menu.`name`,authority_menu.hidden,authority_menu.component,authority_menu.title,authority_menu.icon,authority_menu.sort,authority_menu.menu_id,authority_menu.authority_id FROM sys_menus authority_menu WHERE authority_menu.authority_id = ? AND authority_menu.parent_id = ?"
  16. sql := "SELECT authority_menu.created_at,authority_menu.updated_at,authority_menu.deleted_at,authority_menu.menu_level,authority_menu.parent_id,authority_menu.path,authority_menu.`name`,authority_menu.hidden,authority_menu.component,authority_menu.title,authority_menu.icon,authority_menu.sort,authority_menu.id menu_id,am.sys_authority_authority_id authority_id FROM sys_base_menus authority_menu left join sys_authority_menus am on authority_menu.id = am.sys_base_menu_id WHERE am.sys_authority_authority_id = ? AND authority_menu.parent_id = ? "
  17. err = global.GVA_DB.Raw(sql, authorityId, 0).Scan(&menus).Error
  18. for i := 0; i < len(menus); i++ {
  19. err = getChildrenList(&menus[i], sql)
  20. }
  21. return err, menus
  22. }
  23. // @title getChildrenList
  24. // @description 获取子菜单
  25. // @auth (2020/04/05 20:22)
  26. // @param menu *model.SysMenu
  27. // @param sql string
  28. // @return err error
  29. func getChildrenList(menu *model.SysMenu, sql string) (err error) {
  30. err = global.GVA_DB.Raw(sql, menu.AuthorityId, menu.MenuId).Scan(&menu.Children).Error
  31. for i := 0; i < len(menu.Children); i++ {
  32. err = getChildrenList(&menu.Children[i], sql)
  33. }
  34. return err
  35. }
  36. // @title GetInfoList
  37. // @description 获取路由分页
  38. // @auth (2020/04/05 20:22)
  39. // @param info request.PageInfo
  40. // @return err error
  41. // @return list interface{}
  42. // @return total int
  43. func GetInfoList(info request.PageInfo) (err error, list interface{}, total int) {
  44. limit := info.PageSize
  45. offset := info.PageSize * (info.Page - 1)
  46. db := global.GVA_DB
  47. var menuList []model.SysBaseMenu
  48. err = db.Limit(limit).Offset(offset).Where("parent_id = 0").Order("sort", true).Find(&menuList).Error
  49. for i := 0; i < len(menuList); i++ {
  50. err = getBaseChildrenList(&menuList[i])
  51. }
  52. return err, menuList, total
  53. }
  54. // @title getBaseChildrenList
  55. // @description get children of menu, 获取菜单的子菜单
  56. // @auth (2020/04/05 20:22)
  57. // @param menu *model.SysBaseMenu
  58. // @return err error
  59. func getBaseChildrenList(menu *model.SysBaseMenu) (err error) {
  60. err = global.GVA_DB.Where("parent_id = ?", menu.ID).Order("sort", true).Find(&menu.Children).Error
  61. for i := 0; i < len(menu.Children); i++ {
  62. err = getBaseChildrenList(&menu.Children[i])
  63. }
  64. return err
  65. }
  66. // @title AddBaseMenu
  67. // @description 函数的详细描述
  68. // @auth (2020/04/05 20:22)
  69. // @param menu *model.SysBaseMenu
  70. // @return err error
  71. //增加基础路由
  72. func AddBaseMenu(menu model.SysBaseMenu) (err error) {
  73. findOne := global.GVA_DB.Where("name = ?", menu.Name).Find(&model.SysBaseMenu{}).Error
  74. if findOne != nil {
  75. err = global.GVA_DB.Create(&menu).Error
  76. } else {
  77. err = errors.New("存在重复name,请修改name")
  78. }
  79. return err
  80. }
  81. // @title GetBaseMenuTree
  82. // @description 获取基础路由树
  83. // @auth (2020/04/05 20:22)
  84. // @return err error
  85. // @return menus []SysBaseMenu
  86. func GetBaseMenuTree() (err error, menus []model.SysBaseMenu) {
  87. err = global.GVA_DB.Where(" parent_id = ?", 0).Order("sort", true).Find(&menus).Error
  88. for i := 0; i < len(menus); i++ {
  89. err = getBaseChildrenList(&menus[i])
  90. }
  91. return err, menus
  92. }
  93. // @title AddMenuAuthority
  94. // @description 为角色增加menu树
  95. // @auth (2020/04/05 20:22)
  96. // @param menus []model.SysBaseMenu
  97. // @param authorityId string
  98. // @return error
  99. func AddMenuAuthority(menus []model.SysBaseMenu, authorityId string) (err error) {
  100. var auth model.SysAuthority
  101. auth.AuthorityId = authorityId
  102. auth.SysBaseMenus = menus
  103. err = SetMenuAuthority(&auth)
  104. return err
  105. }
  106. // @title GetMenuAuthority
  107. // @description 查看当前角色树
  108. // @auth (2020/04/05 20:22)
  109. // @param authorityId string
  110. // @return err error
  111. // @return menus []SysBaseMenu
  112. func GetMenuAuthority(authorityId string) (err error, menus []model.SysMenu) {
  113. //sql := "SELECT authority_menu.created_at,authority_menu.updated_at,authority_menu.deleted_at,authority_menu.menu_level,authority_menu.parent_id,authority_menu.path,authority_menu.`name`,authority_menu.hidden,authority_menu.component,authority_menu.title,authority_menu.icon,authority_menu.sort,authority_menu.menu_id,authority_menu.authority_id FROM sys_menus authority_menu WHERE authority_menu.authority_id = ?"
  114. sql := "SELECT authority_menu.created_at,authority_menu.updated_at,authority_menu.deleted_at,authority_menu.menu_level,authority_menu.parent_id,authority_menu.path,authority_menu.`name`,authority_menu.hidden,authority_menu.component,authority_menu.title,authority_menu.icon,authority_menu.sort,authority_menu.id menu_id,am.sys_authority_authority_id authority_id FROM sys_base_menus authority_menu left join sys_authority_menus am on authority_menu.id = am.sys_base_menu_id WHERE am.sys_authority_authority_id = ? "
  115. err = global.GVA_DB.Raw(sql, authorityId).Scan(&menus).Error
  116. return err, menus
  117. }