system_service_more.go 9.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340
  1. package backend
  2. import (
  3. "context"
  4. "fmt"
  5. "kpt-pasture/model"
  6. "net/http"
  7. "go.uber.org/zap"
  8. "gitee.com/xuyiping_admin/pkg/logger/zaplog"
  9. pasturePb "gitee.com/xuyiping_admin/go_proto/proto/go/backend/cow"
  10. operationPb "gitee.com/xuyiping_admin/go_proto/proto/go/backend/operation"
  11. "gitee.com/xuyiping_admin/pkg/xerr"
  12. )
  13. func (s *StoreEntry) SystemMenuTree(ctx context.Context, req *pasturePb.SearchMenuRequest) (*pasturePb.SystemMenuTreeResponse, error) {
  14. userModel, err := s.GetUserModel(ctx)
  15. if err != nil {
  16. return nil, xerr.WithStack(err)
  17. }
  18. systemPastureMenuList := make([]*model.SystemPastureMenu, 0)
  19. if err = s.DB.Model(new(model.SystemPastureMenu)).
  20. Where("pasture_id = ?", userModel.AppPasture.Id).
  21. Find(&systemPastureMenuList).
  22. Error; err != nil {
  23. return nil, xerr.WithStack(err)
  24. }
  25. if len(systemPastureMenuList) <= 0 {
  26. return nil, xerr.Customf("系统菜单未初始化,请联系管理员!")
  27. }
  28. systemMenuList := make([]*model.SystemMenu, 0)
  29. pref := s.DB.Model(new(model.SystemMenu)).
  30. Where("id IN ? ", model.SystemPastureMenuSlice(systemPastureMenuList).GetMenuIds()).
  31. Where("is_delete = ? ", operationPb.IsShow_OK)
  32. if req.Name != "" {
  33. pref.Where("name like ?", fmt.Sprintf("%s%s%s", "%", req.Name, "%"))
  34. }
  35. if err = pref.Order("parent_id ASC,id ASC").
  36. Find(&systemMenuList).Error; err != nil {
  37. return nil, xerr.WithStack(err)
  38. }
  39. return &pasturePb.SystemMenuTreeResponse{
  40. Code: http.StatusOK,
  41. Msg: "ok",
  42. Data: model.SystemMenuSlice(systemMenuList).ToTree(),
  43. }, nil
  44. }
  45. // SearchSystemMenuList 菜单列表查询
  46. func (s *StoreEntry) SearchSystemMenuList(ctx context.Context, req *pasturePb.SearchMenuRequest, pagination *pasturePb.PaginationModel) (*pasturePb.SearchMenuResponse, error) {
  47. userModel, err := s.GetUserModel(ctx)
  48. if err != nil {
  49. return nil, xerr.WithStack(err)
  50. }
  51. systemPastureMenuList := make([]*model.SystemPastureMenu, 0)
  52. if err = s.DB.Model(new(model.SystemPastureMenu)).
  53. Where("pasture_id = ?", userModel.AppPasture.Id).
  54. Find(&systemPastureMenuList).
  55. Error; err != nil {
  56. return nil, xerr.WithStack(err)
  57. }
  58. if len(systemPastureMenuList) <= 0 {
  59. return nil, xerr.Customf("系统菜单未初始化,请联系管理员!")
  60. }
  61. systemMenuList := make([]*model.SystemMenu, 0)
  62. var count int64 = 0
  63. pref := s.DB.Model(new(model.SystemMenu)).
  64. Where("id IN ? ", model.SystemPastureMenuSlice(systemPastureMenuList).GetMenuIds()).
  65. Where("is_delete = ? ", operationPb.IsShow_OK)
  66. if req.Name != "" {
  67. pref.Where("name like ?", fmt.Sprintf("%s%s%s", "%", req.Name, "%"))
  68. }
  69. if err = pref.Order("parent_id").
  70. Count(&count).
  71. Find(&systemMenuList).Error; err != nil {
  72. return nil, xerr.WithStack(err)
  73. }
  74. return &pasturePb.SearchMenuResponse{
  75. Code: http.StatusOK,
  76. Msg: "ok",
  77. Data: &pasturePb.SearchMenuData{
  78. Page: pagination.Page,
  79. Total: int32(count),
  80. PageSize: pagination.PageSize,
  81. List: model.SystemMenuSlice(systemMenuList).ToPB(),
  82. },
  83. }, nil
  84. }
  85. func (s *StoreEntry) SearchSystemDeptList(ctx context.Context, req *pasturePb.SearchDeptRequest, pagination *pasturePb.PaginationModel) (*pasturePb.SearchDeptResponse, error) {
  86. userModel, err := s.GetUserModel(ctx)
  87. if err != nil {
  88. return nil, xerr.WithStack(err)
  89. }
  90. deptList := make([]*model.SystemDept, 0)
  91. var count int64 = 0
  92. pastureId := userModel.AppPasture.Id
  93. pref := s.DB.Model(new(model.SystemDept)).
  94. Where("pasture_id = ?", pastureId).
  95. Where("is_delete = ?", operationPb.IsShow_OK)
  96. if req.Name != "" {
  97. pref.Where("name like ?", fmt.Sprintf("%s%s%s", "%", req.Name, "%"))
  98. }
  99. if req.IsShow > 0 {
  100. pref.Where("is_show = ?", req.IsShow)
  101. }
  102. if err = pref.Order("sort desc").
  103. Count(&count).
  104. Limit(int(pagination.PageSize)).
  105. Offset(int(pagination.PageOffset)).
  106. Find(&deptList).Error; err != nil {
  107. return nil, xerr.WithStack(err)
  108. }
  109. systemUserList, _ := s.SystemUserList(ctx, pastureId)
  110. return &pasturePb.SearchDeptResponse{
  111. Code: http.StatusOK,
  112. Msg: "ok",
  113. Data: &pasturePb.DeptData{
  114. List: model.SystemDeptSlice(deptList).ToPB(systemUserList),
  115. Total: int32(count),
  116. PageSize: pagination.PageSize,
  117. Page: pagination.Page,
  118. },
  119. }, nil
  120. }
  121. func (s *StoreEntry) SystemDepthDelete(ctx context.Context, id int64) error {
  122. userModel, err := s.GetUserModel(ctx)
  123. if err != nil {
  124. return xerr.WithStack(err)
  125. }
  126. dept := &model.SystemDept{}
  127. if err = s.DB.Model(new(model.SystemDept)).
  128. Where("id = ?", id).
  129. Where("pasture_id = ?", userModel.AppPasture.Id).
  130. First(dept).Error; err != nil {
  131. return xerr.WithStack(err)
  132. }
  133. if dept.IsInit == pasturePb.IsShow_Ok {
  134. return xerr.Custom("该部门不可删除")
  135. }
  136. if dept.IsShow == pasturePb.IsShow_No {
  137. return nil
  138. }
  139. if err = s.DB.Model(new(model.SystemDept)).
  140. Where("id = ?", id).
  141. Update("is_delete", operationPb.IsShow_NO).
  142. Error; err != nil {
  143. return xerr.WithStack(err)
  144. }
  145. return nil
  146. }
  147. func (s *StoreEntry) SystemDeptCreateOrUpdate(ctx context.Context, req *pasturePb.SearchDeptRequest) error {
  148. userModel, err := s.GetUserModel(ctx)
  149. if err != nil {
  150. return xerr.WithStack(err)
  151. }
  152. pastureId := userModel.AppPasture.Id
  153. if req.Id > 0 {
  154. systemDept := &model.SystemDept{}
  155. if err = s.DB.Model(new(model.SystemDept)).
  156. Where("id = ?", req.Id).
  157. Where("pasture_id = ?", pastureId).
  158. Where("is_delete = ?", pasturePb.IsShow_Ok).
  159. First(systemDept).Error; err != nil {
  160. zaplog.Error("SystemDeptCreateOrUpdate", zap.Any("req", req), zap.Any("err", err))
  161. return xerr.Customf("部门信息错误: %s", err.Error())
  162. }
  163. // 更新部门信息
  164. systemDept.DepthUpdate(req)
  165. if err = s.DB.Model(new(model.SystemDept)).
  166. Where("id = ?", systemDept.Id).
  167. Where("pasture_id = ?", pastureId).
  168. Select("name", "parent_id", "sort", "remarks", "is_show").
  169. Updates(systemDept).Error; err != nil {
  170. return xerr.WithStack(err)
  171. }
  172. } else {
  173. newSystemDepth := model.NewSystemDept(pastureId, req)
  174. if err = s.DB.Model(new(model.SystemDept)).
  175. Create(newSystemDepth).Error; err != nil {
  176. return xerr.WithStack(err)
  177. }
  178. }
  179. return nil
  180. }
  181. func (s *StoreEntry) SearchUserPastureList(ctx context.Context) (*pasturePb.SystemUserPastureListResponse, error) {
  182. currentUser, err := s.GetCurrentSystemUser(ctx)
  183. if err != nil {
  184. return nil, xerr.WithStack(err)
  185. }
  186. farmList, err := s.FindPastureListByIds(ctx, currentUser.GetPastureIds())
  187. if err != nil {
  188. return nil, xerr.WithStack(err)
  189. }
  190. return &pasturePb.SystemUserPastureListResponse{
  191. Code: http.StatusOK,
  192. Msg: "ok",
  193. Data: model.AppPastureListSlice(farmList).ToPB(),
  194. }, err
  195. }
  196. func (s *StoreEntry) SystemDeptTree(ctx context.Context, req *pasturePb.SearchDeptRequest) (*pasturePb.DeptTreeResponse, error) {
  197. currentUser, err := s.GetCurrentSystemUser(ctx)
  198. if err != nil {
  199. return nil, xerr.WithStack(err)
  200. }
  201. pastureIdsStr := currentUser.PastureIds
  202. if pastureIdsStr == "" {
  203. return nil, xerr.Customf("请先将该用户绑定牧场!谢谢!")
  204. }
  205. pastureIds := currentUser.GetPastureIds()
  206. systemDeptList := make([]*model.SystemDept, 0)
  207. pref := s.DB.Model(new(model.SystemDept)).
  208. Where("is_delete = ?", pasturePb.IsShow_Ok)
  209. if req.PastureId > 0 {
  210. pref.Where("pasture_id = ?", req.PastureId)
  211. } else {
  212. pref.Where("pasture_id IN ?", pastureIds)
  213. }
  214. if req.Name != "" {
  215. pref.Where("name like ?", fmt.Sprintf("%s%s%s", "%", req.Name, "%"))
  216. }
  217. if req.IsShow > 0 {
  218. pref.Where("is_show = ?", req.IsShow)
  219. }
  220. if err = pref.Find(&systemDeptList).Error; err != nil {
  221. return nil, xerr.WithStack(err)
  222. }
  223. if req.Name != "" {
  224. parentDepths, err := s.findAllParentDepths(ctx, systemDeptList, pastureIds)
  225. if err != nil {
  226. return nil, xerr.WithStack(err)
  227. }
  228. systemDeptList = append(systemDeptList, parentDepths...)
  229. }
  230. // 没有搜到部门数据,默认返回所有牧场一级数据
  231. if len(systemDeptList) == 0 {
  232. systemDeptList = s.SearchDepthPastureList(ctx)
  233. }
  234. return &pasturePb.DeptTreeResponse{
  235. Code: http.StatusOK,
  236. Msg: "ok",
  237. Data: model.SystemDeptSlice(systemDeptList).ToTree(),
  238. }, nil
  239. }
  240. func (s *StoreEntry) SearchDepthPastureList(ctx context.Context) []*model.SystemDept {
  241. systemDeptList := make([]*model.SystemDept, 0)
  242. currentUser, err := s.GetCurrentSystemUser(ctx)
  243. if err != nil {
  244. return systemDeptList
  245. }
  246. pastureIds := currentUser.GetPastureIds()
  247. if err = s.DB.Model(new(model.SystemDept)).
  248. Where("is_delete = ?", pasturePb.IsShow_Ok).
  249. Where("pasture_id IN ?", pastureIds).
  250. Where("parent_id = ?", 0).
  251. Find(&systemDeptList).Error; err != nil {
  252. return systemDeptList
  253. }
  254. return systemDeptList
  255. }
  256. // findAllParentDepths 递归查找所有上级部门
  257. func (s *StoreEntry) findAllParentDepths(ctx context.Context, depths []*model.SystemDept, pastureIds []int32) ([]*model.SystemDept, error) {
  258. var allDepths []*model.SystemDept
  259. var parentIDs []int64
  260. foundDepths := make(map[int64]bool)
  261. // 收集所有需要查找的父部门ID
  262. for _, dept := range depths {
  263. if dept.ParentId > 0 && !foundDepths[dept.ParentId] {
  264. parentIDs = append(parentIDs, dept.ParentId)
  265. foundDepths[dept.ParentId] = true
  266. }
  267. }
  268. if len(parentIDs) == 0 {
  269. return allDepths, nil
  270. }
  271. // 查询这些父部门
  272. var parentDepths []*model.SystemDept
  273. if err := s.DB.Model(new(model.SystemDept)).
  274. Where("id IN ?", parentIDs).
  275. Where("pasture_id IN ?", pastureIds).
  276. Where("is_delete = ?", pasturePb.IsShow_Ok).
  277. Find(&parentDepths).Error; err != nil {
  278. return nil, err
  279. }
  280. // 递归查找更上级的部门
  281. higherParents, err := s.findAllParentDepths(ctx, parentDepths, pastureIds)
  282. if err != nil {
  283. return nil, err
  284. }
  285. allDepths = append(allDepths, parentDepths...)
  286. allDepths = append(allDepths, higherParents...)
  287. return allDepths, nil
  288. }