sys_post.go 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
  1. package service
  2. import (
  3. "context"
  4. "dashoo.cn/micro/app/dao"
  5. "dashoo.cn/micro/app/model"
  6. "dashoo.cn/opms_libary/myerrors"
  7. "github.com/gogf/gf/database/gdb"
  8. "github.com/gogf/gf/frame/g"
  9. "github.com/gogf/gf/util/gconv"
  10. )
  11. type PostService struct {
  12. *contextService
  13. Dao *dao.SysPostDao
  14. postRoleDao *dao.SysPostRoleDao
  15. }
  16. func NewPostService(ctx context.Context) (svc *PostService, err error) {
  17. svc = new(PostService)
  18. if svc.contextService, err = svc.Init(ctx); err != nil {
  19. return nil, err
  20. }
  21. svc.Dao = dao.NewSysPostDao(svc.Tenant)
  22. svc.postRoleDao = dao.NewSysPostRoleDao(svc.Tenant)
  23. return svc, nil
  24. }
  25. func (s *PostService) GetList(req *model.SysPostSearchParams) (total int, list []*model.SysPost, err error) {
  26. db := s.Dao.M
  27. if req != nil {
  28. if req.PostCode != "" {
  29. db = db.WhereLike(s.Dao.C.PostCode, req.PostCode)
  30. }
  31. if req.PostName != "" {
  32. db = db.WhereLike(s.Dao.C.PostName, req.PostName)
  33. }
  34. if req.Status != "" {
  35. db = db.Where(s.Dao.C.Status, req.Status)
  36. }
  37. }
  38. total, err = db.Count()
  39. if err != nil {
  40. g.Log().Error(err)
  41. err = myerrors.TipsError("获取总行数失败")
  42. }
  43. err = db.Page(req.GetPage()).OrderAsc(s.Dao.C.Sort).Scan(&list)
  44. if err != nil {
  45. g.Log().Error(err)
  46. err = myerrors.TipsError("获取数据失败")
  47. }
  48. return
  49. }
  50. func (s *PostService) GetEntity(id int64) (post *model.SysPostRes, err error) {
  51. post = new(model.SysPostRes)
  52. err = s.Dao.WherePri(id).Scan(&post.SysPost)
  53. if err != nil {
  54. return nil, err
  55. }
  56. result, err := s.postRoleDao.Fields(dao.SysPostRole.C.RoleId).WherePri(dao.SysPostRole.C.PostId, id).Array()
  57. if err != nil {
  58. return nil, err
  59. }
  60. post.RoleIds = gconv.Ints(result)
  61. return
  62. }
  63. // GetEntityNameByIds根据ID获取名称
  64. func (s *PostService) GetEntityNameByIds(ids []int) ([]string, error) {
  65. result, err := s.Dao.WhereIn(s.Dao.C.Id, ids).Fields(s.Dao.C.PostName).Array()
  66. return gconv.Strings(result), err
  67. }
  68. func (s *PostService) Create(params *model.SysPostReq) error {
  69. data := new(model.SysPost)
  70. if err := gconv.Struct(params, data); err != nil {
  71. return err
  72. }
  73. SetCreatedInfo(data, s.GetCxtUserId(), s.GetCxtUserName())
  74. err := s.Dao.Transaction(context.TODO(), func(ctx context.Context, tx *gdb.TX) error {
  75. lastId, err := s.Dao.TX(tx).InsertAndGetId(data)
  76. if err != nil {
  77. return err
  78. }
  79. err = s.AddPostRole(lastId, params.RoleIds, tx)
  80. return err
  81. })
  82. return err
  83. }
  84. // AddPostRole 添加岗位角色
  85. func (s *PostService) AddPostRole(postId int64, roleIds []int, tx *gdb.TX) (err error) {
  86. //删除旧岗位角色信息
  87. _, err = s.postRoleDao.TX(tx).Where(dao.SysPostRole.C.PostId, postId).Delete()
  88. if err != nil {
  89. return
  90. }
  91. if len(roleIds) == 0 {
  92. return
  93. }
  94. //添加岗位角色
  95. data := g.List{}
  96. for _, v := range roleIds {
  97. data = append(data, g.Map{
  98. dao.SysPostRole.C.PostId: postId,
  99. dao.SysPostRole.C.RoleId: v,
  100. })
  101. }
  102. _, err = s.postRoleDao.TX(tx).Data(data).Insert()
  103. if err != nil {
  104. return
  105. }
  106. return
  107. }
  108. func (s *PostService) UpdateById(params *model.UpdateSysPostReq) (err error) {
  109. data := new(model.SysPost)
  110. if err := gconv.Struct(params, data); err != nil {
  111. return err
  112. }
  113. SetUpdatedInfo(data, s.GetCxtUserId(), s.GetCxtUserName())
  114. err = s.Dao.Transaction(context.TODO(), func(ctx context.Context, tx *gdb.TX) error {
  115. _, err := s.Dao.FieldsEx(UpdateFieldEx...).WherePri(params.Id).Update(data)
  116. if err != nil {
  117. return err
  118. }
  119. err = s.AddPostRole(params.Id, params.RoleIds, tx)
  120. return err
  121. })
  122. return err
  123. }
  124. func (s *PostService) DeleteByIds(ids []int64) error {
  125. _, err := s.Dao.WhereIn(s.Dao.C.Id, ids).Delete()
  126. return err
  127. }