sys_menu.go 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229
  1. // ============================================================================
  2. // This is auto-generated by gf cli tool only once. Fill this file as you wish.
  3. // ============================================================================
  4. package service
  5. import (
  6. "context"
  7. "dashoo.cn/common_definition/admin/menu_def"
  8. "dashoo.cn/micro/app/dao"
  9. "dashoo.cn/micro/app/model"
  10. "dashoo.cn/opms_libary/micro_srv"
  11. "errors"
  12. "github.com/gogf/gf/errors/gerror"
  13. "github.com/gogf/gf/frame/g"
  14. "github.com/gogf/gf/os/glog"
  15. "github.com/gogf/gf/util/gconv"
  16. )
  17. type MenuService struct {
  18. Dao *dao.SysMenuDao
  19. }
  20. func NewMenuService(ctx context.Context) (*MenuService, error) {
  21. menu := new(MenuService)
  22. // 获取租户码
  23. tenant, err := micro_srv.GetTenant(ctx)
  24. if err != nil {
  25. return nil, err
  26. }
  27. reqMethod, _ := micro_srv.GetReqMethod(ctx)
  28. glog.Info("Received " + reqMethod + " request @ " + tenant)
  29. menu.Dao = dao.NewSysMenuDao(tenant)
  30. return menu, err
  31. }
  32. // Create 添加菜单项
  33. func (s MenuService) Create(param *model.SysMenuReq) (id int64, err error) {
  34. // 菜单类型 D目录 M菜单 F按钮或功能 I接口
  35. if param.MenuType == "F" && param.Perms == "" {
  36. return -1, errors.New("权限标识不能为空!")
  37. }
  38. if param.Perms != "" {
  39. count, err := s.Dao.M.Count("Perms", param.Perms)
  40. if err != nil {
  41. return -1, err
  42. }
  43. if count > 0 {
  44. return -1, errors.New("权限标识已存在。")
  45. }
  46. }
  47. if param.MenuType == "D" {
  48. param.Component = "Layout"
  49. }
  50. var entity *model.SysMenu
  51. if err := gconv.Struct(param, &entity); err != nil {
  52. return -1, err
  53. }
  54. // 用户基础信息
  55. //userInfo, err := micro_srv.GetUserInfo(ctx)
  56. //if err != nil {
  57. // return 0, err
  58. //}
  59. SetCreatedInfo(entity, int(1), "userInfo.UserName")
  60. if result, err := s.Dao.M.Insert(entity); err != nil {
  61. return -1, err
  62. } else {
  63. id, err := result.LastInsertId()
  64. if err != nil {
  65. return -1, err
  66. }
  67. //err = s.initPaths(int(id), param.ParentId)
  68. //if err != nil {
  69. // return -1, err
  70. //}
  71. return id, nil
  72. }
  73. }
  74. // UpdateById 根据ID更新菜单项
  75. func (s MenuService) UpdateById(param *model.SysMenuReq) error {
  76. // 菜单类型 D目录 M菜单 F按钮或功能 I接口
  77. if param.MenuType == "F" && param.Perms == "" {
  78. return gerror.New("权限标识不能为空!")
  79. }
  80. if param.MenuType == "D" {
  81. param.Component = "Layout"
  82. }
  83. var entity *model.SysMenu
  84. if err := gconv.Struct(param, &entity); err != nil {
  85. g.Log().Error(err)
  86. return gerror.New("数据转换异常,请重新尝试")
  87. }
  88. db := s.Dao.M
  89. menu, err := db.FindOne("Id", entity.Id)
  90. if err != nil {
  91. return err
  92. }
  93. if menu.IsEmpty() {
  94. return gerror.New("菜单不存在")
  95. }
  96. if entity.Perms != "" {
  97. exist, err := db.Where("Id !=?", entity.Id).Where("perms", entity.Perms).FindOne()
  98. if err != nil {
  99. return err
  100. }
  101. if !exist.IsEmpty() {
  102. return gerror.New("权限标识已存在。")
  103. }
  104. }
  105. // 用户基础信息
  106. //userInfo, err := micro_srv.GetUserInfo(ctx)
  107. //if err != nil {
  108. // return err
  109. //}
  110. SetUpdatedInfo(entity, int(1), "userInfo.UserName")
  111. _, err = db.FieldsEx(UpdateFieldEx).Where("Id", entity.Id).Update(entity)
  112. if err != nil {
  113. return err
  114. }
  115. //err = s.savePaths(ctx, entity.Id, entity.ParentId, menu["Paths"].String())
  116. return err
  117. }
  118. func (s MenuService) Delete(id int64) (err error) {
  119. db := s.Dao.M
  120. record, err := db.FindOne("Id", id)
  121. if err != nil {
  122. return err
  123. }
  124. if record.IsEmpty() {
  125. return gerror.New("菜单不存在")
  126. }
  127. _, err = db.Delete("Id", id)
  128. //delParentId := record["ParentId"].String()
  129. //if err != nil {
  130. // return err
  131. //}
  132. //res, _ := db.Data("parent_id", delParentId).Where("parent_id", id).Update()
  133. //
  134. //if res != nil {
  135. // if delParentId == "0" {
  136. // updatesql := "Paths = replace(Paths, '" + strconv.Itoa(id) + "/" + "', '')"
  137. // _, err = db.Update(updatesql, " Paths like '"+strconv.Itoa(id)+"/%'")
  138. // } else {
  139. // updatesql := "Paths = replace(Paths, '" + record["Paths"].String() + "', '" + delParentId + "')"
  140. // _, err = db.Update(updatesql, " Paths like '"+record["Paths"].String()+"/%'")
  141. // }
  142. //}
  143. return err
  144. }
  145. // GetEntity 获取菜单项实体
  146. func (s MenuService) GetEntity(id int64) (*model.SysMenu, error) {
  147. one, err := s.Dao.M.FindOne(id)
  148. if err != nil {
  149. return nil, err
  150. }
  151. if one.IsEmpty() {
  152. return nil, nil
  153. }
  154. var entity *model.SysMenu
  155. if err = one.Struct(&entity); err != nil {
  156. return nil, err
  157. }
  158. return entity, nil
  159. }
  160. // GetList 获取菜单列表
  161. func (s MenuService) GetList(param *menu_def.SelectReq) ([]model.SysMenu, error) {
  162. db := s.Dao.M
  163. if param != nil {
  164. if param.Title != "" {
  165. db = db.Where("menu_name like ?", "%"+param.Title+"%")
  166. }
  167. if param.Visible != "" {
  168. db = db.Where("visible", param.Visible)
  169. }
  170. if param.Order != "" {
  171. sort := "ASC"
  172. if !param.IsAsc {
  173. sort = "DESC"
  174. }
  175. db = db.Order(param.Order + " " + sort)
  176. } else {
  177. db = db.Order("sort")
  178. }
  179. }
  180. result := make([]model.SysMenu, 0)
  181. if err := db.FindScan(&result); err != nil {
  182. return nil, err
  183. }
  184. return result, nil
  185. }
  186. // GetMenuTree 获取菜单树
  187. func (s MenuService) GetMenuTree(isAll bool) ([]model.MenuTree, error) {
  188. db := s.Dao.M
  189. menuType := g.Slice{"M", "C"}
  190. if isAll {
  191. menuType = g.Slice{"M", "C", "F"}
  192. }
  193. menuList := make([]model.SysMenu, 0)
  194. err := db.Where("status = 10").Where("menu_type IN (?)", menuType).Order("sort").Scan(&menuList)
  195. treeMap := make(map[int][]model.MenuTree, 0)
  196. for _, v := range menuList {
  197. treeMap[v.ParentId] = append(treeMap[v.ParentId], v.ConvMenuTree())
  198. }
  199. menuTree := treeMap[0]
  200. for i := 0; i < len(menuTree); i++ {
  201. s.getChildrenList(&menuTree[i], treeMap)
  202. }
  203. return menuTree, err
  204. }
  205. // getChildrenList 获取菜单的子菜单
  206. func (s MenuService) getChildrenList(menu *model.MenuTree, treeMap map[int][]model.MenuTree) {
  207. if value, ok := treeMap[menu.Id]; ok {
  208. menu.Children = value
  209. for i := 0; i < len(menu.Children); i++ {
  210. s.getChildrenList(&menu.Children[i], treeMap)
  211. }
  212. }
  213. }