update_sop_task_logic.go 1.8 KB

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