sop_task_stop_logic.go 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. package sop_task
  2. import (
  3. "context"
  4. "fmt"
  5. "github.com/suyuan32/simple-admin-common/msg/errormsg"
  6. "wechat-api/ent/messagerecords"
  7. "wechat-api/ent/sopstage"
  8. "wechat-api/ent/soptask"
  9. "wechat-api/internal/utils/dberrorhandler"
  10. "wechat-api/internal/svc"
  11. "wechat-api/internal/types"
  12. "github.com/zeromicro/go-zero/core/logx"
  13. )
  14. type SopTaskStopLogic struct {
  15. logx.Logger
  16. ctx context.Context
  17. svcCtx *svc.ServiceContext
  18. }
  19. func NewSopTaskStopLogic(ctx context.Context, svcCtx *svc.ServiceContext) *SopTaskStopLogic {
  20. return &SopTaskStopLogic{
  21. Logger: logx.WithContext(ctx),
  22. ctx: ctx,
  23. svcCtx: svcCtx}
  24. }
  25. func (l *SopTaskStopLogic) SopTaskStop(req *types.IDReq) (resp *types.BaseMsgResp, err error) {
  26. organizationId := l.ctx.Value("organizationId").(uint64)
  27. isAdmin := l.ctx.Value("isAdmin").(bool)
  28. // 开始事务
  29. tx, err := l.svcCtx.DB.Tx(context.Background())
  30. if err != nil {
  31. return nil, dberrorhandler.DefaultEntError(l.Logger, err, req)
  32. }
  33. // 根据 id 查询 task 信息,如果 Status 的值不为 1,则不允许修改
  34. task, err := tx.SopTask.Query().
  35. Where(
  36. soptask.IDEQ(req.Id), // Filter by ID
  37. soptask.OrganizationID(organizationId), // Additional filter by organizationId
  38. ).
  39. Only(l.ctx)
  40. if err != nil {
  41. return nil, dberrorhandler.DefaultEntError(l.Logger, err, req)
  42. }
  43. if task.Status != 3 {
  44. return nil, dberrorhandler.DefaultEntError(l.Logger, err, req)
  45. }
  46. if isAdmin {
  47. err = tx.SopTask.UpdateOneID(req.Id).
  48. SetStatus(1).
  49. Exec(l.ctx)
  50. sourceInfo, err := l.svcCtx.DB.SopStage.Query().
  51. Where(sopstage.TaskID(req.Id)).
  52. WithStageNodes().
  53. All(l.ctx)
  54. fmt.Printf("------------------------sourceInfo------------------------: %+v\n", sourceInfo)
  55. if err != nil {
  56. return nil, dberrorhandler.DefaultEntError(l.Logger, err, req)
  57. }
  58. for _, stage := range sourceInfo {
  59. fmt.Printf("------------------------stage.ID------------------------: %+v\n", stage.ID)
  60. _, err := tx.MessageRecords.Delete().Where(messagerecords.SourceIDEQ(stage.ID)).Exec(l.ctx)
  61. if err != nil {
  62. return nil, dberrorhandler.DefaultEntError(l.Logger, err, req)
  63. }
  64. for _, node := range stage.Edges.StageNodes {
  65. _, err := tx.MessageRecords.Delete().Where(messagerecords.SourceIDEQ(node.ID)).Exec(l.ctx)
  66. if err != nil {
  67. return nil, dberrorhandler.DefaultEntError(l.Logger, err, req)
  68. }
  69. }
  70. }
  71. } else {
  72. err = tx.SopTask.UpdateOneID(req.Id).
  73. SetStatus(2).
  74. Exec(l.ctx)
  75. }
  76. if err != nil {
  77. _ = tx.Rollback()
  78. return nil, dberrorhandler.DefaultEntError(l.Logger, err, req)
  79. }
  80. // 查询task的所有sop_stages
  81. for _, stage := range task.Edges.TaskStages {
  82. // 更新最旧的 p.Number 条 status 值为 1 或 4 的 message_records 记录的 status 为 2
  83. messages, _ := tx.MessageRecords.Query().
  84. Where(messagerecords.StatusIn(1, 2, 4), messagerecords.SourceType(3), messagerecords.SourceID(stage.ID)).
  85. All(l.ctx)
  86. for _, m := range messages {
  87. _, err := tx.MessageRecords.UpdateOneID(m.ID).SetStatus(5).Save(l.ctx)
  88. if err != nil {
  89. _ = tx.Rollback()
  90. }
  91. }
  92. }
  93. err = tx.Commit()
  94. if err != nil {
  95. return nil, dberrorhandler.DefaultEntError(l.Logger, err, req)
  96. }
  97. return &types.BaseMsgResp{Msg: errormsg.UpdateSuccess}, nil
  98. }