main.go 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. /*
  2. Licensed under the Apache License, Version 2.0 (the "License");
  3. you may not use this file except in compliance with the License.
  4. You may obtain a copy of the License at
  5. http://www.apache.org/licenses/LICENSE-2.0
  6. Unless required by applicable law or agreed to in writing, software
  7. distributed under the License is distributed on an "AS IS" BASIS,
  8. WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  9. See the License for the specific language governing permissions and
  10. limitations under the License.
  11. */
  12. // Code generated by providers/v2/hack/generate-provider-main.go. DO NOT EDIT.
  13. package main
  14. import (
  15. "flag"
  16. "fmt"
  17. "log"
  18. "net"
  19. "os"
  20. "os/signal"
  21. "syscall"
  22. genv1alpha1 "github.com/external-secrets/external-secrets/apis/generators/v1alpha1"
  23. awsv2alpha1 "github.com/external-secrets/external-secrets/apis/provider/aws/v2alpha1"
  24. genpb "github.com/external-secrets/external-secrets/proto/generator"
  25. pb "github.com/external-secrets/external-secrets/proto/provider"
  26. "github.com/external-secrets/external-secrets/providers/v2/adapter"
  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. log.Printf("starting on port %d (TLS: %v, Verbose: %v)", *port, *enableTLS, *verbose)
  49. // Create Kubernetes client (required by adapter)
  50. scheme := runtime.NewScheme()
  51. _ = clientgoscheme.AddToScheme(scheme)
  52. _ = awsv2alpha1.AddToScheme(scheme)
  53. _ = genv1alpha1.AddToScheme(scheme)
  54. cfg, err := config.GetConfig()
  55. if err != nil {
  56. log.Fatalf("Failed to get kubeconfig: %v", err)
  57. }
  58. kubeClient, err := client.New(cfg, client.Options{Scheme: scheme})
  59. if err != nil {
  60. log.Fatalf("Failed to create Kubernetes client: %v", err)
  61. }
  62. // Setup v1 provider(s)
  63. v1Provider0 := store.NewProvider()
  64. v1Provider1 := store.NewProvider()
  65. providerMapping := adapterstore.ProviderMapping{
  66. schema.GroupVersionKind{
  67. Group: "provider.external-secrets.io",
  68. Version: "v2alpha1",
  69. Kind: "SecretsManager",
  70. }: v1Provider0,
  71. schema.GroupVersionKind{
  72. Group: "provider.external-secrets.io",
  73. Version: "v2alpha1",
  74. Kind: "ParameterStore",
  75. }: v1Provider1,
  76. }
  77. specMapper := GetSpecMapper(kubeClient)
  78. // Setup v1 generator(s)
  79. generatorMapping := adaptergenerator.Mapping{
  80. schema.GroupVersionKind{
  81. Group: "generators.external-secrets.io",
  82. Version: "v1alpha1",
  83. Kind: "ECRAuthorizationToken",
  84. }: generator.NewECRGenerator(),
  85. schema.GroupVersionKind{
  86. Group: "generators.external-secrets.io",
  87. Version: "v1alpha1",
  88. Kind: "STSSessionToken",
  89. }: generator.NewSTSGenerator(),
  90. }
  91. adapterServer := adapter.NewServer(kubeClient, scheme, providerMapping, specMapper, generatorMapping)
  92. log.Printf("[PROVIDER] Using v1 AWS Provider provider with generators wrapped with v2 adapter")
  93. grpcServer, err := grpcserver.NewGRPCServer(grpcserver.ServerOptions{
  94. EnableTLS: *enableTLS,
  95. Verbose: *verbose,
  96. })
  97. if err != nil {
  98. log.Fatalf("Failed to create gRPC server: %v", err)
  99. }
  100. // Register services
  101. pb.RegisterSecretStoreProviderServer(grpcServer, adapterServer)
  102. genpb.RegisterGeneratorProviderServer(grpcServer, adapterServer)
  103. // Register health service
  104. healthServer := health.NewServer()
  105. grpc_health_v1.RegisterHealthServer(grpcServer, healthServer)
  106. healthServer.SetServingStatus("", grpc_health_v1.HealthCheckResponse_SERVING)
  107. // Register reflection service for debugging
  108. reflection.Register(grpcServer)
  109. // Start listening
  110. lis, err := net.Listen("tcp", fmt.Sprintf(":%d", *port))
  111. if err != nil {
  112. log.Fatalf("Failed to listen: %v", err)
  113. }
  114. // Handle graceful shutdown
  115. go func() {
  116. sigChan := make(chan os.Signal, 1)
  117. signal.Notify(sigChan, syscall.SIGINT, syscall.SIGTERM)
  118. sig := <-sigChan
  119. log.Printf("Received signal: %v, shutting down gracefully...", sig)
  120. grpcServer.GracefulStop()
  121. }()
  122. // Start serving
  123. log.Printf("AWS Provider Provider listening on %s", lis.Addr().String())
  124. if err := grpcServer.Serve(lis); err != nil {
  125. log.Fatalf("Failed to serve: %v", err)
  126. }
  127. }