main.go 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160
  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. genv1alpha1 "github.com/external-secrets/external-secrets/apis/generators/v1alpha1"
  24. awsv2alpha1 "github.com/external-secrets/external-secrets/apis/provider/aws/v2alpha1"
  25. genpb "github.com/external-secrets/external-secrets/proto/generator"
  26. pb "github.com/external-secrets/external-secrets/proto/provider"
  27. adaptergenerator "github.com/external-secrets/external-secrets/providers/v2/adapter/generator"
  28. adapterstore "github.com/external-secrets/external-secrets/providers/v2/adapter/store"
  29. generator "github.com/external-secrets/external-secrets/providers/v2/aws/generator"
  30. store "github.com/external-secrets/external-secrets/providers/v2/aws/store"
  31. grpcserver "github.com/external-secrets/external-secrets/providers/v2/common/grpc/server"
  32. "google.golang.org/grpc/health"
  33. "google.golang.org/grpc/health/grpc_health_v1"
  34. "google.golang.org/grpc/reflection"
  35. "k8s.io/apimachinery/pkg/runtime"
  36. "k8s.io/apimachinery/pkg/runtime/schema"
  37. clientgoscheme "k8s.io/client-go/kubernetes/scheme"
  38. "sigs.k8s.io/controller-runtime/pkg/client"
  39. "sigs.k8s.io/controller-runtime/pkg/client/config"
  40. )
  41. var (
  42. port = flag.Int("port", 8080, "The server port")
  43. enableTLS = flag.Bool("enable-tls", true, "Enable TLS/mTLS for gRPC server")
  44. verbose = flag.Bool("verbose", false, "Enable verbose connection-level debugging")
  45. )
  46. func main() {
  47. flag.Parse()
  48. ctx, stop := signal.NotifyContext(context.Background(), syscall.SIGINT, syscall.SIGTERM)
  49. defer stop()
  50. log.Printf("starting on port %d (TLS: %v, Verbose: %v)", *port, *enableTLS, *verbose)
  51. // Create Kubernetes client (required by adapter)
  52. scheme := runtime.NewScheme()
  53. _ = clientgoscheme.AddToScheme(scheme)
  54. _ = awsv2alpha1.AddToScheme(scheme)
  55. _ = genv1alpha1.AddToScheme(scheme)
  56. cfg, err := config.GetConfig()
  57. if err != nil {
  58. log.Fatalf("Failed to get kubeconfig: %v", err)
  59. }
  60. kubeClient, err := client.New(cfg, client.Options{Scheme: scheme})
  61. if err != nil {
  62. log.Fatalf("Failed to create Kubernetes client: %v", err)
  63. }
  64. // Setup v1 provider(s)
  65. v1Provider0 := store.NewProvider()
  66. v1Provider1 := store.NewProvider()
  67. compatibilityProvider := v1Provider0
  68. providerMapping := adapterstore.ProviderMapping{
  69. schema.GroupVersionKind{
  70. Group: "provider.external-secrets.io",
  71. Version: "v2alpha1",
  72. Kind: "SecretsManager",
  73. }: v1Provider0,
  74. schema.GroupVersionKind{
  75. Group: "provider.external-secrets.io",
  76. Version: "v2alpha1",
  77. Kind: "ParameterStore",
  78. }: v1Provider1,
  79. }
  80. specMapper := GetSpecMapper(kubeClient)
  81. // Setup v1 generator(s)
  82. generatorMapping := adaptergenerator.Mapping{
  83. schema.GroupVersionKind{
  84. Group: "generators.external-secrets.io",
  85. Version: "v1alpha1",
  86. Kind: "ECRAuthorizationToken",
  87. }: generator.NewECRGenerator(),
  88. schema.GroupVersionKind{
  89. Group: "generators.external-secrets.io",
  90. Version: "v1alpha1",
  91. Kind: "STSSessionToken",
  92. }: generator.NewSTSGenerator(),
  93. }
  94. storeServer := adapterstore.NewServerWithCompatibilityProvider(kubeClient, providerMapping, specMapper, compatibilityProvider)
  95. generatorServer := adaptergenerator.NewServer(kubeClient, scheme, generatorMapping)
  96. log.Printf("[PROVIDER] Using v1 AWS Provider provider with generators wrapped with v2 adapter")
  97. grpcServer, err := grpcserver.NewGRPCServer(grpcserver.ServerOptions{
  98. EnableTLS: *enableTLS,
  99. Verbose: *verbose,
  100. })
  101. if err != nil {
  102. log.Fatalf("Failed to create gRPC server: %v", err)
  103. }
  104. metricsServer := grpcserver.NewMetricsServer(grpcserver.DefaultMetricsPort, nil)
  105. if err := grpcserver.RegisterMetrics(metricsServer.GetRegistry()); err != nil {
  106. log.Fatalf("Failed to register metrics: %v", err)
  107. }
  108. // Register services
  109. pb.RegisterSecretStoreProviderServer(grpcServer, storeServer)
  110. genpb.RegisterGeneratorProviderServer(grpcServer, generatorServer)
  111. // Register health service
  112. healthServer := health.NewServer()
  113. grpc_health_v1.RegisterHealthServer(grpcServer, healthServer)
  114. healthServer.SetServingStatus("", grpc_health_v1.HealthCheckResponse_SERVING)
  115. // Register reflection service for debugging
  116. reflection.Register(grpcServer)
  117. // Start listening
  118. lis, err := net.Listen("tcp", fmt.Sprintf(":%d", *port))
  119. if err != nil {
  120. log.Fatalf("Failed to listen: %v", err)
  121. }
  122. go func() {
  123. if err := metricsServer.Start(ctx); err != nil {
  124. log.Fatalf("Failed to start metrics server: %v", err)
  125. }
  126. }()
  127. // Handle graceful shutdown
  128. go func() {
  129. <-ctx.Done()
  130. log.Printf("Received shutdown signal, stopping gRPC server...")
  131. grpcServer.GracefulStop()
  132. }()
  133. // Start serving
  134. log.Printf("AWS Provider Provider listening on %s", lis.Addr().String())
  135. if err := grpcServer.Serve(lis); err != nil {
  136. log.Fatalf("Failed to serve: %v", err)
  137. }
  138. }