forked from choria-io/asyncjobs
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy patherrors.go
117 lines (108 loc) · 7.28 KB
/
errors.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
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
// Copyright (c) 2022, R.I. Pienaar and the Project contributors
//
// SPDX-License-Identifier: Apache-2.0
package asyncjobs
import (
"errors"
"fmt"
)
var (
// ErrTaskNotFound is the error indicating a task does not exist rather than a failure to load
ErrTaskNotFound = errors.New("task not found")
// ErrTerminateTask indicates that a task failed, and no further processing attempts should be made
ErrTerminateTask = fmt.Errorf("terminate task")
// ErrNoTasks indicates the task store is empty
ErrNoTasks = fmt.Errorf("no tasks found")
// ErrTaskPastDeadline indicates a task that was scheduled for handling is past its deadline
ErrTaskPastDeadline = fmt.Errorf("past deadline")
// ErrTaskExceedsMaxTries indicates a task exceeded its maximum attempts
ErrTaskExceedsMaxTries = fmt.Errorf("exceeded maximum tries")
// ErrTaskAlreadyActive indicates that a task is already in the active state
ErrTaskAlreadyActive = fmt.Errorf("task already active")
// ErrTaskTypeCannotEnqueue indicates that a task is in a state where it cannot be enqueued as new
ErrTaskTypeCannotEnqueue = fmt.Errorf("cannot enqueue a task in state")
// ErrTaskUpdateFailed indicates a task update failed
ErrTaskUpdateFailed = fmt.Errorf("failed updating task state")
// ErrTaskAlreadyInState indicates an update failed because a task was already in the desired state
ErrTaskAlreadyInState = fmt.Errorf("%w, already in desired state", ErrTaskUpdateFailed)
// ErrTaskLoadFailed indicates a task failed for an unknown reason
ErrTaskLoadFailed = fmt.Errorf("loading task failed")
// ErrTaskTypeRequired indicates an empty task type was given
ErrTaskTypeRequired = fmt.Errorf("task type is required")
// ErrTaskTypeInvalid indicates an invalid task type was given
ErrTaskTypeInvalid = fmt.Errorf("task type is invalid")
// ErrTaskDependenciesFailed indicates that the task cannot be run as its dependencies failed
ErrTaskDependenciesFailed = fmt.Errorf("task dependencies failed")
// ErrTaskAlreadySigned indicates a task is already signed
ErrTaskAlreadySigned = fmt.Errorf("task is already signed")
// ErrTaskSignatureRequiresQueue indicates a signature request was made without configuring the queue name for a task
ErrTaskSignatureRequiresQueue = fmt.Errorf("signing a task requires the queue to be set")
// ErrTaskNotSigned indicates a task was loaded that had no signature while signatures are required
ErrTaskNotSigned = fmt.Errorf("task is not signed")
// ErrTaskSignatureInvalid indicates a signature did not pass validation
ErrTaskSignatureInvalid = fmt.Errorf("invalid task signature")
// ErrNoHandlerForTaskType indicates that a task could not be handled by any known handlers
ErrNoHandlerForTaskType = fmt.Errorf("no handler for task type")
// ErrDuplicateHandlerForTaskType indicates a task handler for a specific type is already registered
ErrDuplicateHandlerForTaskType = fmt.Errorf("duplicate handler for task type")
// ErrInvalidHeaders indicates that message headers from JetStream were not valid
ErrInvalidHeaders = fmt.Errorf("coult not decode headers")
// ErrContextWithoutDeadline indicates a context.Context was passed without deadline when it was expected
ErrContextWithoutDeadline = fmt.Errorf("non deadline context given")
// ErrInvalidStorageItem indicates a Work Queue item had no JetStream state associated with it
ErrInvalidStorageItem = fmt.Errorf("invalid storage item")
// ErrNoNatsConn indicates that a nil connection was supplied
ErrNoNatsConn = fmt.Errorf("no NATS connection supplied")
// ErrNoMux indicates that a processor was started with no routing mux configured
ErrNoMux = fmt.Errorf("mux is required")
// ErrStorageNotReady indicates the underlying storage is not ready
ErrStorageNotReady = fmt.Errorf("storage not ready")
// ErrQueueNotFound is the error indicating a queue does not exist rather than a failure to load
ErrQueueNotFound = errors.New("queue not found")
// ErrQueueConsumerNotFound indicates that the Work Queue store has no consumers defined
ErrQueueConsumerNotFound = errors.New("queue consumer not found")
// ErrQueueNameRequired indicates a queue has no name
ErrQueueNameRequired = fmt.Errorf("queue name is required")
// ErrQueueItemCorrupt indicates that an item received from the work queue was invalid - perhaps invalid JSON
ErrQueueItemCorrupt = fmt.Errorf("corrupt queue item received")
// ErrQueueItemInvalid is an item read from the queue with no data or obviously bad data
ErrQueueItemInvalid = fmt.Errorf("invalid queue item received")
// ErrInvalidQueueState indicates a queue was attempted to be used but no internal state is known of that queue
ErrInvalidQueueState = fmt.Errorf("invalid queue storage state")
// ErrDuplicateItem indicates that the Work Queue deduplication protection refused a message
ErrDuplicateItem = fmt.Errorf("duplicate work queue item")
// ErrExternalCommandNotFound indicates a command for an ExternalProcess handler was not found
ErrExternalCommandNotFound = fmt.Errorf("command not found")
// ErrExternalCommandFailed indicates a command for an ExternalProcess handler failed
ErrExternalCommandFailed = fmt.Errorf("execution failed")
// ErrUnknownEventType indicates that while parsing an event an unknown type of event was encountered
ErrUnknownEventType = fmt.Errorf("unknown event type")
// ErrUnknownRetryPolicy indicates the requested retry policy does not exist
ErrUnknownRetryPolicy = fmt.Errorf("unknown retry policy")
// ErrUnknownDiscardPolicy indicates a discard policy could not be found matching a name
ErrUnknownDiscardPolicy = fmt.Errorf("unknown discard policy")
// ErrInvalidPrivateKey indicates the private key is not valid
ErrInvalidPrivateKey = fmt.Errorf("invalid private key length")
// ErrRequestReplyFailed indicates a callout to a remote handler failed due to a timeout, lack of listeners or network error
ErrRequestReplyFailed = fmt.Errorf("request-reply callout failed")
// ErrRequestReplyNoDeadline indicates a request-reply handler was called without a deadline
ErrRequestReplyNoDeadline = fmt.Errorf("request-reply requires deadline context")
// ErrRequestReplyShortDeadline indicates a deadline context has a too short timeout
ErrRequestReplyShortDeadline = fmt.Errorf("deadline too short")
// ErrScheduleNameIsRequired indicates a schedule name is needed when creating new schedules
ErrScheduleNameIsRequired = errors.New("name is required")
// ErrScheduleNameInvalid indicates the name given to a task is invalid
ErrScheduleNameInvalid = errors.New("name is invalid")
// ErrScheduleIsRequired indicates a cron schedule must be supplied when creating new schedules
ErrScheduleIsRequired = errors.New("schedule is required")
// ErrScheduleInvalid indicates an invalid cron schedule was supplied
ErrScheduleInvalid = errors.New("invalid cron schedule")
// ErrScheduledTaskAlreadyExist indicates a scheduled task that was being created already existed
ErrScheduledTaskAlreadyExist = errors.New("scheduled task already exist")
// ErrScheduledTaskNotFound indicates the requested task does not exist
ErrScheduledTaskNotFound = errors.New("scheduled task not found")
// ErrScheduledTaskInvalid indicates a loaded task was invalid
ErrScheduledTaskInvalid = errors.New("invalid scheduled task")
// ErrScheduledTaskShortDeadline indicates the time allowed for task execution is too short
ErrScheduledTaskShortDeadline = errors.New("deadline too short")
)