update_sop_task_logic.go 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. package sop_task
  2. import (
  3. "context"
  4. "fmt"
  5. "wechat-api/ent/soptask"
  6. "wechat-api/internal/svc"
  7. "wechat-api/internal/types"
  8. "wechat-api/internal/utils/dberrorhandler"
  9. "github.com/suyuan32/simple-admin-common/msg/errormsg"
  10. "github.com/suyuan32/simple-admin-common/utils/pointy"
  11. "github.com/zeromicro/go-zero/core/logx"
  12. )
  13. type UpdateSopTaskLogic struct {
  14. ctx context.Context
  15. svcCtx *svc.ServiceContext
  16. logx.Logger
  17. }
  18. func NewUpdateSopTaskLogic(ctx context.Context, svcCtx *svc.ServiceContext) *UpdateSopTaskLogic {
  19. return &UpdateSopTaskLogic{
  20. ctx: ctx,
  21. svcCtx: svcCtx,
  22. Logger: logx.WithContext(ctx),
  23. }
  24. }
  25. func (l *UpdateSopTaskLogic) UpdateSopTask(req *types.SopTaskInfo) (*types.BaseMsgResp, error) {
  26. organizationId := l.ctx.Value("organizationId").(uint64)
  27. // 判断 planEndTime 和 planStartTime 是否非空,且 planEndTime 是否大于 planStartTime
  28. if req.PlanEndTime != nil && req.PlanStartTime != nil && (*req.PlanEndTime <= *req.PlanStartTime) {
  29. return nil, dberrorhandler.DefaultEntError(l.Logger, fmt.Errorf("planEndTime must be greater than planStartTime"), req)
  30. }
  31. err := l.svcCtx.DB.SopTask.UpdateOneID(*req.Id).
  32. Where(soptask.StatusEQ(1), soptask.OrganizationID(organizationId)).
  33. SetNotNilStatus(req.Status).
  34. SetNotNilName(req.Name).
  35. SetNotNilBotWxidList(req.BotWxidList).
  36. SetNotNilType(req.Type).
  37. SetNotNilPlanStartTime(pointy.GetTimeMilliPointer(req.PlanStartTime)).
  38. SetNotNilPlanEndTime(pointy.GetTimeMilliPointer(req.PlanEndTime)).
  39. SetNotNilCreatorID(req.CreatorId).
  40. Exec(l.ctx)
  41. if err != nil {
  42. return nil, dberrorhandler.DefaultEntError(l.Logger, err, req)
  43. }
  44. return &types.BaseMsgResp{Msg: errormsg.UpdateSuccess}, nil
  45. }