-
Notifications
You must be signed in to change notification settings - Fork 416
/
tekton.go
46 lines (43 loc) · 1.36 KB
/
tekton.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
package tekton
import (
"github.com/tektoncd/pipeline/pkg/apis/pipeline"
"github.com/tektoncd/triggers/pkg/apis/triggers"
"github.com/tektoncd/triggers/pkg/client/dynamic/clientset"
"k8s.io/apimachinery/pkg/runtime/schema"
"k8s.io/client-go/dynamic"
)
var (
allowedPipelineTypes = map[string][]string{
"v1alpha1": {"pipelineresources", "pipelineruns", "taskruns", "pipelines", "clustertasks", "tasks", "conditions"},
"v1beta1": {"pipelineruns", "taskruns", "pipelines", "clustertasks", "tasks"},
}
allowedTriggersTypes = map[string][]string{
"v1alpha1": {"clusterinterceptors"},
"v1beta1": {"clustertriggerbindings", "eventlisteners", "triggerbindings", "triggers", "triggertemplates"},
}
)
// WithClient adds Tekton related clients to the Dynamic client.
func WithClient(client dynamic.Interface) clientset.Option {
return func(cs *clientset.Clientset) {
for version, resources := range allowedPipelineTypes {
for _, resource := range resources {
r := schema.GroupVersionResource{
Group: pipeline.GroupName,
Version: version,
Resource: resource,
}
cs.Add(r, client)
}
}
for version, resources := range allowedTriggersTypes {
for _, resource := range resources {
r := schema.GroupVersionResource{
Group: triggers.GroupName,
Version: version,
Resource: resource,
}
cs.Add(r, client)
}
}
}
}