This repository has been archived by the owner on Nov 28, 2022. It is now read-only.
forked from knative/eventing
/
cron_job_lifecycle.go
123 lines (97 loc) · 5.38 KB
/
cron_job_lifecycle.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
118
119
120
121
122
123
/*
Copyright 2019 The Knative Authors
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
package v1alpha1
import (
"github.com/knative/pkg/apis"
)
const (
// CronJobConditionReady has status True when the CronJobSource is ready to send events.
CronJobConditionReady = apis.ConditionReady
// CronJobConditionValidSchedule has status True when the CronJobSource has been configured with a valid schedule.
CronJobConditionValidSchedule apis.ConditionType = "ValidSchedule"
// CronJobConditionSinkProvided has status True when the CronJobSource has been configured with a sink target.
CronJobConditionSinkProvided apis.ConditionType = "SinkProvided"
// CronJobConditionDeployed has status True when the CronJobSource has had it's receive adapter deployment created.
CronJobConditionDeployed apis.ConditionType = "Deployed"
// CronJobConditionEventTypeProvided has status True when the CronJobSource has been configured with its event type.
CronJobConditionEventTypeProvided apis.ConditionType = "EventTypeProvided"
// CronJobConditionResources is True when the resources listed for the CronJobSource have been properly
// parsed and match specified syntax for resource quantities
CronJobConditionResources apis.ConditionType = "ResourcesCorrect"
)
var cronJobSourceCondSet = apis.NewLivingConditionSet(
CronJobConditionValidSchedule,
CronJobConditionSinkProvided,
CronJobConditionDeployed)
// GetCondition returns the condition currently associated with the given type, or nil.
func (s *CronJobSourceStatus) GetCondition(t apis.ConditionType) *apis.Condition {
return cronJobSourceCondSet.Manage(s).GetCondition(t)
}
// IsReady returns true if the resource is ready overall.
func (s *CronJobSourceStatus) IsReady() bool {
return cronJobSourceCondSet.Manage(s).IsHappy()
}
// InitializeConditions sets relevant unset conditions to Unknown state.
func (s *CronJobSourceStatus) InitializeConditions() {
cronJobSourceCondSet.Manage(s).InitializeConditions()
}
// TODO: this is a bad method name, change it.
// MarkSchedule sets the condition that the source has a valid schedule configured.
func (s *CronJobSourceStatus) MarkSchedule() {
cronJobSourceCondSet.Manage(s).MarkTrue(CronJobConditionValidSchedule)
}
// MarkInvalidSchedule sets the condition that the source does not have a valid schedule configured.
func (s *CronJobSourceStatus) MarkInvalidSchedule(reason, messageFormat string, messageA ...interface{}) {
cronJobSourceCondSet.Manage(s).MarkFalse(CronJobConditionValidSchedule, reason, messageFormat, messageA...)
}
// MarkSink sets the condition that the source has a sink configured.
func (s *CronJobSourceStatus) MarkSink(uri string) {
s.SinkURI = uri
if len(uri) > 0 {
cronJobSourceCondSet.Manage(s).MarkTrue(CronJobConditionSinkProvided)
} else {
cronJobSourceCondSet.Manage(s).MarkUnknown(CronJobConditionSinkProvided, "SinkEmpty", "Sink has resolved to empty.%s", "")
}
}
// MarkNoSink sets the condition that the source does not have a sink configured.
func (s *CronJobSourceStatus) MarkNoSink(reason, messageFormat string, messageA ...interface{}) {
cronJobSourceCondSet.Manage(s).MarkFalse(CronJobConditionSinkProvided, reason, messageFormat, messageA...)
}
// MarkDeployed sets the condition that the source has been deployed.
func (s *CronJobSourceStatus) MarkDeployed() {
cronJobSourceCondSet.Manage(s).MarkTrue(CronJobConditionDeployed)
}
// MarkDeploying sets the condition that the source is deploying.
func (s *CronJobSourceStatus) MarkDeploying(reason, messageFormat string, messageA ...interface{}) {
cronJobSourceCondSet.Manage(s).MarkUnknown(CronJobConditionDeployed, reason, messageFormat, messageA...)
}
// MarkNotDeployed sets the condition that the source has not been deployed.
func (s *CronJobSourceStatus) MarkNotDeployed(reason, messageFormat string, messageA ...interface{}) {
cronJobSourceCondSet.Manage(s).MarkFalse(CronJobConditionDeployed, reason, messageFormat, messageA...)
}
// MarkEventType sets the condition that the source has set its event type.
func (s *CronJobSourceStatus) MarkEventType() {
cronJobSourceCondSet.Manage(s).MarkTrue(CronJobConditionEventTypeProvided)
}
// MarkNoEventType sets the condition that the source does not its event type configured.
func (s *CronJobSourceStatus) MarkNoEventType(reason, messageFormat string, messageA ...interface{}) {
cronJobSourceCondSet.Manage(s).MarkFalse(CronJobConditionEventTypeProvided, reason, messageFormat, messageA...)
}
// MarkResourcesCorrect sets the condtion that the source resources are properly parsable quantities
func (s *CronJobSourceStatus) MarkResourcesCorrect() {
cronJobSourceCondSet.Manage(s).MarkTrue(CronJobConditionResources)
}
// MarkResourcesInorrect sets the condtion that the source resources are not properly parsable quantities
func (s *CronJobSourceStatus) MarkResourcesIncorrect(reason, messageFormat string, messageA ...interface{}) {
cronJobSourceCondSet.Manage(s).MarkFalse(CronJobConditionResources, reason, messageFormat, messageA...)
}