main.go 4.2 KB

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