From febe994b1e531a7d5c25eda722e0dccff216e1a7 Mon Sep 17 00:00:00 2001 From: Derrick Hammer Date: Mon, 12 Aug 2024 18:51:46 -0400 Subject: [PATCH] feat: add Context() method and update job retrieval, closes #762 - Add Context() method to Job interface and implement it in job struct - Update requestJob function to include a timeout flag - Modify existing methods to use the new requestJob signature --- job.go | 15 +++++++++++---- util.go | 12 +++++++++--- 2 files changed, 20 insertions(+), 7 deletions(-) diff --git a/job.go b/job.go index d43b7d1b..1bed1997 100644 --- a/job.go +++ b/job.go @@ -995,6 +995,7 @@ type Job interface { // Tags returns the job's string tags. Tags() []string Lock() Lock + Context() context.Context } var _ Job = (*job)(nil) @@ -1016,7 +1017,7 @@ func (j job) ID() uuid.UUID { } func (j job) LastRun() (time.Time, error) { - ij := requestJob(j.id, j.jobOutRequest) + ij := requestJob(j.id, j.jobOutRequest, true) if ij == nil || ij.id == uuid.Nil { return time.Time{}, ErrJobNotFound } @@ -1028,7 +1029,7 @@ func (j job) Name() string { } func (j job) NextRun() (time.Time, error) { - ij := requestJob(j.id, j.jobOutRequest) + ij := requestJob(j.id, j.jobOutRequest, true) if ij == nil || ij.id == uuid.Nil { return time.Time{}, ErrJobNotFound } @@ -1041,7 +1042,7 @@ func (j job) NextRun() (time.Time, error) { } func (j job) NextRuns(count int) ([]time.Time, error) { - ij := requestJob(j.id, j.jobOutRequest) + ij := requestJob(j.id, j.jobOutRequest, true) if ij == nil || ij.id == uuid.Nil { return nil, ErrJobNotFound } @@ -1095,7 +1096,13 @@ func (j job) RunNow() error { } func (j job) Lock() Lock { - ij := requestJob(j.id, j.jobOutRequest) + ij := requestJob(j.id, j.jobOutRequest, true) return ij.lastLock } + +func (j job) Context() context.Context { + ij := requestJob(j.id, j.jobOutRequest, false) + + return ij.ctx +} diff --git a/util.go b/util.go index a4e5b6fd..65511e75 100644 --- a/util.go +++ b/util.go @@ -36,9 +36,15 @@ func callJobFuncWithParams(jobFunc any, params ...any) error { return nil } -func requestJob(id uuid.UUID, ch chan jobOutRequest) *internalJob { - ctx, cancel := context.WithTimeout(context.Background(), time.Second) - defer cancel() +func requestJob(id uuid.UUID, ch chan jobOutRequest, timeout bool) *internalJob { + var cancel context.CancelFunc + ctx := context.Background() + + if timeout { + ctx, cancel = context.WithTimeout(context.Background(), time.Second) + defer cancel() + } + return requestJobCtx(ctx, id, ch) }