-
Notifications
You must be signed in to change notification settings - Fork 98
/
knativeeventing_types.go
106 lines (87 loc) · 3.63 KB
/
knativeeventing_types.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
/*
Copyright 2022 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 v1beta1
import (
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"knative.dev/operator/pkg/apis/operator/base"
duckv1 "knative.dev/pkg/apis/duck/v1"
)
var (
_ base.KComponent = (*KnativeEventing)(nil)
_ base.KComponentSpec = (*KnativeEventingSpec)(nil)
)
// KnativeEventing is the Schema for the eventings API
// +genclient
// +genreconciler:krshapedlogic=false
// +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object
type KnativeEventing struct {
metav1.TypeMeta `json:",inline"`
metav1.ObjectMeta `json:"metadata,omitempty"`
Spec KnativeEventingSpec `json:"spec,omitempty"`
Status KnativeEventingStatus `json:"status,omitempty"`
}
// GetSpec implements KComponent
func (ke *KnativeEventing) GetSpec() base.KComponentSpec {
return &ke.Spec
}
// GetStatus implements KComponent
func (ke *KnativeEventing) GetStatus() base.KComponentStatus {
return &ke.Status
}
// KnativeEventingSpec defines the desired state of KnativeEventing
type KnativeEventingSpec struct {
base.CommonSpec `json:",inline"`
// The default broker type to use for the brokers Knative creates.
// If no value is provided, MTChannelBasedBroker will be used.
// +optional
DefaultBrokerClass string `json:"defaultBrokerClass,omitempty"`
// SinkBindingSelectionMode specifies the NamespaceSelector and ObjectSelector
// for the sinkbinding webhook.
// If `inclusion` is selected, namespaces/objects labelled as `bindings.knative.dev/include:true`
// will be considered by the sinkbinding webhook;
// If `exclusion` is selected, namespaces/objects labelled as `bindings.knative.dev/exclude:true`
// will NOT be considered by the sinkbinding webhook.
// If no SINK_BINDING_SELECTION_MODE env var is given in the workloadOverrides for the
// sinkinding webhook, the default `exclusion` is used.
// +optional
SinkBindingSelectionMode string `json:"sinkBindingSelectionMode,omitempty"`
// Source allows configuration of different eventing sources to be shipped.
// +optional
Source *SourceConfigs `json:"source,omitempty"`
}
// KnativeEventingStatus defines the observed state of KnativeEventing
type KnativeEventingStatus struct {
duckv1.Status `json:",inline"`
// The version of the installed release
// +optional
Version string `json:"version,omitempty"`
// The url links of the manifests, separated by comma
// +optional
Manifests []string `json:"manifests,omitempty"`
}
// KnativeEventingList contains a list of KnativeEventing
// +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object
type KnativeEventingList struct {
metav1.TypeMeta `json:",inline"`
metav1.ListMeta `json:"metadata,omitempty"`
Items []KnativeEventing `json:"items"`
}
// SourceConfigs specifies options for the eventing sources.
type SourceConfigs struct {
Ceph base.CephSourceConfiguration `json:"ceph"`
Github base.GithubSourceConfiguration `json:"github"`
Gitlab base.GitlabSourceConfiguration `json:"gitlab"`
Kafka base.KafkaSourceConfiguration `json:"kafka"`
Rabbitmq base.RabbitmqSourceConfiguration `json:"rabbitmq"`
Redis base.RedisSourceConfiguration `json:"redis"`
}