-
Notifications
You must be signed in to change notification settings - Fork 136
/
Copy pathmain.go
89 lines (70 loc) · 3.04 KB
/
main.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
package main
import (
"flag"
"fmt"
"net"
"os"
"os/signal"
"syscall"
"google.golang.org/grpc"
"k8s.io/client-go/kubernetes"
"k8s.io/client-go/rest"
"k8s.io/klog/v2"
csidriver "sigs.k8s.io/secrets-store-csi-driver/provider/v1alpha1"
"github.com/aws/secrets-store-csi-driver-provider-aws/auth"
"github.com/aws/secrets-store-csi-driver-provider-aws/provider"
"github.com/aws/secrets-store-csi-driver-provider-aws/server"
)
var (
endpointDir = flag.String("provider-volume", "/etc/kubernetes/secrets-store-csi-providers", "Rendezvous directory for provider socket")
driverWriteSecrets = flag.Bool("driver-writes-secrets", false, "The driver will do the write instead of the plugin")
qps = flag.Int("qps", 5, "Maximum query per second to the Kubernetes API server. To mount the requested secret on the pod, the AWS CSI provider lookups the region of the pod and the role ARN associated with the service account by calling the K8s APIs. Increase the value if the provider is throttled by client-side limit to the API server.")
burst = flag.Int("burst", 10, "Maximum burst for throttle. To mount the requested secret on the pod, the AWS CSI provider lookups the region of the pod and the role ARN associated with the service account by calling the K8s APIs. Increase the value if the provider is throttled by client-side limit to the API server.")
)
// Main entry point for the Secret Store CSI driver AWS provider. This main
// rountine starts up the gRPC server that will listen for incoming mount
// requests.
func main() {
klog.Infof("Starting %s version %s", auth.ProviderName, server.Version)
flag.Parse() // Parse command line flags
//socket on which to listen to for driver calls
endpoint := fmt.Sprintf("%s/aws.sock", *endpointDir)
os.Remove(endpoint) // Make sure to start clean.
grpcSrv := grpc.NewServer()
//Gracefully terminate server on shutdown unix signals
sigs := make(chan os.Signal, 1)
signal.Notify(sigs, syscall.SIGTERM, syscall.SIGINT)
go func() {
sig := <-sigs
klog.Infof("received signal:%s to terminate", sig)
grpcSrv.GracefulStop()
}()
listener, err := net.Listen("unix", endpoint)
if err != nil {
klog.Fatalf("Failed to listen on unix socket. error: %v", err)
}
cfg, err := rest.InClusterConfig()
if err != nil {
klog.Fatalf("Can not get cluster config. error: %v", err)
}
cfg.QPS = float32(*qps)
cfg.Burst = *burst
clientset, err := kubernetes.NewForConfig(cfg)
if err != nil {
klog.Fatalf("Can not initialize kubernetes client. error: %v", err)
}
defer func() { // Cleanup on shutdown
listener.Close()
os.Remove(endpoint)
}()
providerSrv, err := server.NewServer(provider.NewSecretProviderFactory, clientset.CoreV1(), *driverWriteSecrets)
if err != nil {
klog.Fatalf("Could not create server. error: %v", err)
}
csidriver.RegisterCSIDriverProviderServer(grpcSrv, providerSrv)
klog.Infof("Listening for connections on address: %s", listener.Addr())
err = grpcSrv.Serve(listener)
if err != nil {
klog.Fatalf("Failure serving incoming mount requests. error: %v", err)
}
}