/
job.go
59 lines (45 loc) · 1.26 KB
/
job.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
package worker
import (
"time"
"github.com/hibiken/asynq"
)
type (
// Job represents a unit of work to be performed.
Job = asynq.Task
// JobPayload holds arbitrary data needed for job processing.
JobPayload = asynq.Payload
// JobOptions specifies how a job should be processed.
JobOptions struct {
Deadline time.Time
MaxRetry int
Queue string
Timeout time.Duration
UniqueTTL time.Duration
}
)
// NewJob initializes a job with a unique identifier and its data for background job processing.
func NewJob(id string, data map[string]interface{}) *Job {
return asynq.NewTask(id, data)
}
func parseJobOptions(opts *JobOptions) []asynq.Option {
asynqOptions := []asynq.Option{}
if opts == nil {
return asynqOptions
}
if !opts.Deadline.IsZero() {
asynqOptions = append(asynqOptions, asynq.Deadline(opts.Deadline))
}
if opts.MaxRetry != 0 {
asynqOptions = append(asynqOptions, asynq.MaxRetry(opts.MaxRetry))
}
if opts.Queue != "" && opts.Queue != "default" {
asynqOptions = append(asynqOptions, asynq.Queue(opts.Queue))
}
if opts.Timeout != 0 {
asynqOptions = append(asynqOptions, asynq.Timeout(opts.Timeout))
}
if opts.UniqueTTL != 0 {
asynqOptions = append(asynqOptions, asynq.Unique(opts.UniqueTTL))
}
return asynqOptions
}