get_task_by_id_logic.go 1.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. package task
  2. import (
  3. "context"
  4. "github.com/suyuan32/simple-admin-job/internal/svc"
  5. "github.com/suyuan32/simple-admin-job/internal/utils/dberrorhandler"
  6. "github.com/suyuan32/simple-admin-job/types/job"
  7. "github.com/suyuan32/simple-admin-common/utils/pointy"
  8. "github.com/zeromicro/go-zero/core/logx"
  9. )
  10. type GetTaskByIdLogic struct {
  11. ctx context.Context
  12. svcCtx *svc.ServiceContext
  13. logx.Logger
  14. }
  15. func NewGetTaskByIdLogic(ctx context.Context, svcCtx *svc.ServiceContext) *GetTaskByIdLogic {
  16. return &GetTaskByIdLogic{
  17. ctx: ctx,
  18. svcCtx: svcCtx,
  19. Logger: logx.WithContext(ctx),
  20. }
  21. }
  22. func (l *GetTaskByIdLogic) GetTaskById(in *job.IDReq) (*job.TaskInfo, error) {
  23. result, err := l.svcCtx.DB.Task.Get(l.ctx, in.Id)
  24. if err != nil {
  25. return nil, dberrorhandler.DefaultEntError(l.Logger, err, in)
  26. }
  27. return &job.TaskInfo{
  28. Id: &result.ID,
  29. CreatedAt: pointy.GetPointer(result.CreatedAt.UnixMilli()),
  30. UpdatedAt: pointy.GetPointer(result.UpdatedAt.UnixMilli()),
  31. Status: pointy.GetPointer(uint32(result.Status)),
  32. Name: &result.Name,
  33. TaskGroup: &result.TaskGroup,
  34. CronExpression: &result.CronExpression,
  35. Pattern: &result.Pattern,
  36. Payload: &result.Payload,
  37. }, nil
  38. }