-
Notifications
You must be signed in to change notification settings - Fork 4.6k
/
lifecycle.go
66 lines (52 loc) · 2.36 KB
/
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
/*
Copyright 2017 The Kubernetes 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 fi
import "k8s.io/apimachinery/pkg/util/sets"
type Lifecycle string
const (
// LifecycleSync should do the normal synchronization
LifecycleSync Lifecycle = "Sync"
// LifecycleIgnore will skip the task
LifecycleIgnore Lifecycle = "Ignore"
// LifecycleWarnIfInsufficientAccess will warn but ignore the task if there is an error during the find
LifecycleWarnIfInsufficientAccess Lifecycle = "WarnIfInsufficientAccess"
// LifecycleExistsAndValidates will check that the task exists and is the same
LifecycleExistsAndValidates Lifecycle = "ExistsAndValidates"
// LifecycleExistsAndWarnIfChanges will check that the task exists and will warn on changes, but then ignore them
LifecycleExistsAndWarnIfChanges Lifecycle = "ExistsAndWarnIfChanges"
)
// HasLifecycle indicates that the task has a Lifecycle
type HasLifecycle interface {
GetLifecycle() *Lifecycle
// SetLifecycle is used to override a tasks lifecycle. If a lifecycle override exists for a specific task name, then the
// lifecycle is modified.
SetLifecycle(lifecycle Lifecycle)
}
// Lifecycles are used for ux validation. When validation fails the lifecycle names are
// printed out.
var Lifecycles = sets.NewString(
string(LifecycleSync),
string(LifecycleIgnore),
string(LifecycleWarnIfInsufficientAccess),
string(LifecycleExistsAndValidates),
string(LifecycleExistsAndWarnIfChanges),
)
// LifecycleNameMap is used to validate in the UX. When a user provides a lifecycle name
// it then can be mapped to the actual lifecycle.
var LifecycleNameMap = map[string]Lifecycle{
"Sync": LifecycleSync,
"Ignore": LifecycleIgnore,
"WarnIfInsufficientAccess": LifecycleWarnIfInsufficientAccess,
"ExistsAndValidates": LifecycleExistsAndValidates,
"ExistsAndWarnIfChanges": LifecycleExistsAndWarnIfChanges,
}