main.go.tmpl 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191
  1. /*
  2. Copyright © The ESO Authors
  3. Licensed under the Apache License, Version 2.0 (the "License");
  4. you may not use this file except in compliance with the License.
  5. You may obtain a copy of the License at
  6. https://www.apache.org/licenses/LICENSE-2.0
  7. Unless required by applicable law or agreed to in writing, software
  8. distributed under the License is distributed on an "AS IS" BASIS,
  9. WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  10. See the License for the specific language governing permissions and
  11. limitations under the License.
  12. */
  13. // Code generated by providers/v2/hack/generate-provider-main.go. DO NOT EDIT.
  14. package main
  15. import (
  16. "context"
  17. "flag"
  18. "fmt"
  19. "log"
  20. "net"
  21. "os/signal"
  22. "syscall"
  23. "google.golang.org/grpc/health"
  24. "google.golang.org/grpc/health/grpc_health_v1"
  25. "google.golang.org/grpc/reflection"
  26. "k8s.io/apimachinery/pkg/runtime"
  27. "k8s.io/apimachinery/pkg/runtime/schema"
  28. clientgoscheme "k8s.io/client-go/kubernetes/scheme"
  29. "sigs.k8s.io/controller-runtime/pkg/client"
  30. "sigs.k8s.io/controller-runtime/pkg/client/config"
  31. {{- if .HasGenerators}}
  32. genv1alpha1 "github.com/external-secrets/external-secrets/apis/generators/v1alpha1"
  33. {{- end}}
  34. {{- if .Provider.Provider.V2Package}}
  35. {{.Provider.Provider.Name}}v2alpha1 "{{.Provider.Provider.V2Package}}"
  36. {{- end}}
  37. {{- if .HasGenerators}}
  38. genpb "github.com/external-secrets/external-secrets/proto/generator"
  39. {{- end}}
  40. {{- if .HasStores}}
  41. pb "github.com/external-secrets/external-secrets/proto/provider"
  42. {{- end}}
  43. {{- if .HasGenerators}}
  44. adaptergenerator "github.com/external-secrets/external-secrets/providers/v2/adapter/generator"
  45. {{- end}}
  46. {{- if .HasStores}}
  47. adapterstore "github.com/external-secrets/external-secrets/providers/v2/adapter/store"
  48. {{- end}}
  49. grpcserver "github.com/external-secrets/external-secrets/providers/v2/common/grpc/server"
  50. {{- range .UniqueStoreImports}}
  51. {{.Alias}} "{{.Path}}"
  52. {{- end}}
  53. {{- range .UniqueGeneratorImports}}
  54. {{.Alias}} "{{.Path}}"
  55. {{- end}}
  56. )
  57. var (
  58. port = flag.Int("port", 8080, "The server port")
  59. enableTLS = flag.Bool("enable-tls", true, "Enable TLS/mTLS for gRPC server")
  60. verbose = flag.Bool("verbose", false, "Enable verbose connection-level debugging")
  61. )
  62. func main() {
  63. flag.Parse()
  64. ctx, stop := signal.NotifyContext(context.Background(), syscall.SIGINT, syscall.SIGTERM)
  65. defer stop()
  66. log.Printf("starting on port %d (TLS: %v, Verbose: %v)", *port, *enableTLS, *verbose)
  67. // Create Kubernetes client (required by adapter)
  68. scheme := runtime.NewScheme()
  69. _ = clientgoscheme.AddToScheme(scheme)
  70. {{- if .Provider.Provider.V2Package}}
  71. _ = {{.Provider.Provider.Name}}v2alpha1.AddToScheme(scheme)
  72. {{- end}}
  73. {{- if .HasGenerators}}
  74. _ = genv1alpha1.AddToScheme(scheme)
  75. {{- end}}
  76. cfg, err := config.GetConfig()
  77. if err != nil {
  78. log.Fatalf("Failed to get kubeconfig: %v", err)
  79. }
  80. kubeClient, err := client.New(cfg, client.Options{Scheme: scheme})
  81. if err != nil {
  82. log.Fatalf("Failed to create Kubernetes client: %v", err)
  83. }
  84. {{- if .HasStores}}
  85. // Setup v1 provider(s)
  86. {{- range $idx, $store := .Stores}}
  87. v1Provider{{$idx}} := {{$store.ImportAlias}}.{{$store.V1ProviderFunc}}()
  88. {{- end}}
  89. compatibilityProvider := v1Provider0
  90. providerMapping := adapterstore.ProviderMapping{
  91. {{- range $idx, $store := .Stores}}
  92. schema.GroupVersionKind{
  93. Group: "{{$store.GVK.Group}}",
  94. Version: "{{$store.GVK.Version}}",
  95. Kind: "{{$store.GVK.Kind}}",
  96. }: v1Provider{{$idx}},
  97. {{- end}}
  98. }
  99. specMapper := GetSpecMapper(kubeClient)
  100. {{- end}}
  101. {{- if .HasGenerators}}
  102. // Setup v1 generator(s)
  103. generatorMapping := adaptergenerator.Mapping{
  104. {{- range $idx, $gen := .Generators}}
  105. schema.GroupVersionKind{
  106. Group: "{{$gen.GVK.Group}}",
  107. Version: "{{$gen.GVK.Version}}",
  108. Kind: "{{$gen.GVK.Kind}}",
  109. }: {{$gen.ImportAlias}}.{{$gen.V1GeneratorFunc}}(),
  110. {{- end}}
  111. }
  112. {{- end}}
  113. {{- if .HasStores}}
  114. storeServer := adapterstore.NewServerWithCompatibilityProvider(kubeClient, providerMapping, specMapper, compatibilityProvider)
  115. {{- end}}
  116. {{- if .HasGenerators}}
  117. generatorServer := adaptergenerator.NewServer(kubeClient, scheme, generatorMapping)
  118. {{- end}}
  119. log.Printf("[PROVIDER] Using v1 {{.Provider.Provider.DisplayName}} provider{{if .HasGenerators}} with generators{{end}} wrapped with v2 adapter")
  120. grpcServer, err := grpcserver.NewGRPCServer(grpcserver.ServerOptions{
  121. EnableTLS: *enableTLS,
  122. Verbose: *verbose,
  123. })
  124. if err != nil {
  125. log.Fatalf("Failed to create gRPC server: %v", err)
  126. }
  127. metricsServer := grpcserver.NewMetricsServer(grpcserver.DefaultMetricsPort, nil)
  128. if err := grpcserver.RegisterMetrics(metricsServer.GetRegistry()); err != nil {
  129. log.Fatalf("Failed to register metrics: %v", err)
  130. }
  131. // Register services
  132. {{- if .HasStores}}
  133. pb.RegisterSecretStoreProviderServer(grpcServer, storeServer)
  134. {{- end}}
  135. {{- if .HasGenerators}}
  136. genpb.RegisterGeneratorProviderServer(grpcServer, generatorServer)
  137. {{- end}}
  138. // Register health service
  139. healthServer := health.NewServer()
  140. grpc_health_v1.RegisterHealthServer(grpcServer, healthServer)
  141. healthServer.SetServingStatus("", grpc_health_v1.HealthCheckResponse_SERVING)
  142. // Register reflection service for debugging
  143. reflection.Register(grpcServer)
  144. // Start listening
  145. lis, err := net.Listen("tcp", fmt.Sprintf(":%d", *port))
  146. if err != nil {
  147. log.Fatalf("Failed to listen: %v", err)
  148. }
  149. go func() {
  150. if err := metricsServer.Start(ctx); err != nil {
  151. log.Fatalf("Failed to start metrics server: %v", err)
  152. }
  153. }()
  154. // Handle graceful shutdown
  155. go func() {
  156. <-ctx.Done()
  157. log.Printf("Received shutdown signal, stopping gRPC server...")
  158. grpcServer.GracefulStop()
  159. }()
  160. // Start serving
  161. log.Printf("{{.Provider.Provider.DisplayName}} Provider listening on %s", lis.Addr().String())
  162. if err := grpcServer.Serve(lis); err != nil {
  163. log.Fatalf("Failed to serve: %v", err)
  164. }
  165. }