-
Notifications
You must be signed in to change notification settings - Fork 419
/
auth_override.go
79 lines (69 loc) · 2.71 KB
/
auth_override.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
/*
Copyright 2020 The Tekton 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 sink
import (
"fmt"
dynamicClientset "github.com/tektoncd/triggers/pkg/client/dynamic/clientset"
"github.com/tektoncd/triggers/pkg/client/dynamic/clientset/tekton"
"go.uber.org/zap"
discoveryclient "k8s.io/client-go/discovery"
"k8s.io/client-go/dynamic"
"k8s.io/client-go/kubernetes"
"k8s.io/client-go/rest"
)
// AuthOverride is an interface that constructs a discovery client for the ServerResourceInterface
// and a dynamic client for the Tekton Resources, using the token provide as the bearer token in the
// REST config used to build those client. The other non-credential related parameters for the
// REST client used are copied from the in cluster config of the event sink.
type AuthOverride interface {
OverrideAuthentication(sa string,
namespace string,
log *zap.SugaredLogger,
defaultDiscoveryClient discoveryclient.ServerResourcesInterface,
defaultDynamicClient dynamic.Interface) (discoveryClient discoveryclient.ServerResourcesInterface,
dynamicClient dynamic.Interface,
err error)
}
type DefaultAuthOverride struct {
}
func (r DefaultAuthOverride) OverrideAuthentication(sa string,
namespace string,
log *zap.SugaredLogger,
defaultDiscoverClient discoveryclient.ServerResourcesInterface,
defaultDynamicClient dynamic.Interface) (discoveryClient discoveryclient.ServerResourcesInterface,
dynamicClient dynamic.Interface,
err error) {
dynamicClient = defaultDynamicClient
discoveryClient = defaultDiscoverClient
clusterConfig, err := rest.InClusterConfig()
if err != nil {
log.Errorf("overrideAuthentication: problem getting in cluster config: %#v\n", err)
return
}
clusterConfig.Impersonate = rest.ImpersonationConfig{
UserName: fmt.Sprintf("system:serviceaccount:%s:%s", namespace, sa),
}
dc, err := dynamic.NewForConfig(clusterConfig)
if err != nil {
log.Errorf("overrideAuthentication: problem getting dynamic client set: %#v\n", err)
return
}
kubeClient, err := kubernetes.NewForConfig(clusterConfig)
if err != nil {
log.Errorf("overrideAuthentication: problem getting kube client: %#v\n", err)
return
}
dynamicClient = dynamicClientset.New(tekton.WithClient(dc))
discoveryClient = kubeClient.Discovery()
return
}