mirror of
https://github.com/kyverno/kyverno.git
synced 2024-12-14 11:57:48 +00:00
e3b74f1384
* feat: add options to configure resync period for informers in helm chart Signed-off-by: Vishal Choudhary <vishal.choudhary@nirmata.com> * fix: codegen Signed-off-by: Vishal Choudhary <vishal.choudhary@nirmata.com> --------- Signed-off-by: Vishal Choudhary <vishal.choudhary@nirmata.com>
137 lines
5.7 KiB
Go
137 lines
5.7 KiB
Go
package internal
|
|
|
|
import (
|
|
"context"
|
|
"time"
|
|
|
|
"github.com/go-logr/logr"
|
|
apiserverclient "github.com/kyverno/kyverno/pkg/clients/apiserver"
|
|
"github.com/kyverno/kyverno/pkg/clients/dclient"
|
|
dynamicclient "github.com/kyverno/kyverno/pkg/clients/dynamic"
|
|
kubeclient "github.com/kyverno/kyverno/pkg/clients/kube"
|
|
kyvernoclient "github.com/kyverno/kyverno/pkg/clients/kyverno"
|
|
metadataclient "github.com/kyverno/kyverno/pkg/clients/metadata"
|
|
"github.com/kyverno/kyverno/pkg/config"
|
|
"github.com/kyverno/kyverno/pkg/engine/jmespath"
|
|
"github.com/kyverno/kyverno/pkg/imageverifycache"
|
|
"github.com/kyverno/kyverno/pkg/metrics"
|
|
"github.com/kyverno/kyverno/pkg/registryclient"
|
|
reportutils "github.com/kyverno/kyverno/pkg/utils/report"
|
|
eventsv1 "k8s.io/client-go/kubernetes/typed/events/v1"
|
|
corev1listers "k8s.io/client-go/listers/core/v1"
|
|
)
|
|
|
|
func shutdown(logger logr.Logger, sdowns ...context.CancelFunc) context.CancelFunc {
|
|
return func() {
|
|
for i := range sdowns {
|
|
if sdowns[i] != nil {
|
|
logger.Info("shutting down...")
|
|
defer sdowns[i]()
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
type SetupResult struct {
|
|
Logger logr.Logger
|
|
Configuration config.Configuration
|
|
MetricsConfiguration config.MetricsConfiguration
|
|
MetricsManager metrics.MetricsConfigManager
|
|
Jp jmespath.Interface
|
|
KubeClient kubeclient.UpstreamInterface
|
|
LeaderElectionClient kubeclient.UpstreamInterface
|
|
RegistryClient registryclient.Client
|
|
ImageVerifyCacheClient imageverifycache.Client
|
|
RegistrySecretLister corev1listers.SecretNamespaceLister
|
|
KyvernoClient kyvernoclient.UpstreamInterface
|
|
DynamicClient dynamicclient.UpstreamInterface
|
|
ApiServerClient apiserverclient.UpstreamInterface
|
|
MetadataClient metadataclient.UpstreamInterface
|
|
KyvernoDynamicClient dclient.Interface
|
|
EventsClient eventsv1.EventsV1Interface
|
|
ReportingConfiguration reportutils.ReportingConfiguration
|
|
ResyncPeriod time.Duration
|
|
}
|
|
|
|
func Setup(config Configuration, name string, skipResourceFilters bool) (context.Context, SetupResult, context.CancelFunc) {
|
|
logger := setupLogger()
|
|
showVersion(logger)
|
|
printFlagSettings(logger)
|
|
showWarnings(config, logger)
|
|
check(logger)
|
|
sdownMaxProcs := setupMaxProcs(logger)
|
|
setupProfiling(logger)
|
|
ctx, sdownSignals := setupSignals(logger)
|
|
client := kubeclient.From(createKubernetesClient(logger, clientRateLimitQPS, clientRateLimitBurst), kubeclient.WithTracing())
|
|
metricsConfiguration := startMetricsConfigController(ctx, logger, client)
|
|
metricsManager, sdownMetrics := SetupMetrics(ctx, logger, metricsConfiguration, client)
|
|
client = client.WithMetrics(metricsManager, metrics.KubeClient)
|
|
configuration := startConfigController(ctx, logger, client, skipResourceFilters)
|
|
sdownTracing := SetupTracing(logger, name, client)
|
|
var registryClient registryclient.Client
|
|
var registrySecretLister corev1listers.SecretNamespaceLister
|
|
if config.UsesRegistryClient() {
|
|
registryClient, registrySecretLister = setupRegistryClient(ctx, logger, client)
|
|
}
|
|
var imageVerifyCache imageverifycache.Client
|
|
if config.UsesImageVerifyCache() {
|
|
imageVerifyCache = setupImageVerifyCache(logger)
|
|
}
|
|
if config.UsesCosign() {
|
|
setupSigstoreTUF(ctx, logger)
|
|
}
|
|
var leaderElectionClient kubeclient.UpstreamInterface
|
|
if config.UsesLeaderElection() {
|
|
leaderElectionClient = createKubernetesClient(logger, clientRateLimitQPS, clientRateLimitBurst, kubeclient.WithMetrics(metricsManager, metrics.KubeClient), kubeclient.WithTracing())
|
|
}
|
|
var kyvernoClient kyvernoclient.UpstreamInterface
|
|
if config.UsesKyvernoClient() {
|
|
kyvernoClient = createKyvernoClient(logger, kyvernoclient.WithMetrics(metricsManager, metrics.KyvernoClient), kyvernoclient.WithTracing())
|
|
}
|
|
var dynamicClient dynamicclient.UpstreamInterface
|
|
if config.UsesDynamicClient() {
|
|
dynamicClient = createDynamicClient(logger, dynamicclient.WithMetrics(metricsManager, metrics.DynamicClient), dynamicclient.WithTracing())
|
|
}
|
|
var apiServerClient apiserverclient.UpstreamInterface
|
|
if config.UsesApiServerClient() {
|
|
apiServerClient = createApiServerClient(logger, apiserverclient.WithMetrics(metricsManager, metrics.ApiServerClient), apiserverclient.WithTracing())
|
|
}
|
|
var dClient dclient.Interface
|
|
if config.UsesKyvernoDynamicClient() {
|
|
dClient = createKyvernoDynamicClient(logger, ctx, dynamicClient, client, resyncPeriod)
|
|
}
|
|
var eventsClient eventsv1.EventsV1Interface
|
|
if config.UsesEventsClient() {
|
|
eventsClient = createEventsClient(logger, metricsManager)
|
|
}
|
|
var metadataClient metadataclient.UpstreamInterface
|
|
if config.UsesMetadataClient() {
|
|
metadataClient = createMetadataClient(logger, metadataclient.WithMetrics(metricsManager, metrics.MetadataClient), metadataclient.WithTracing())
|
|
}
|
|
var reportingConfig reportutils.ReportingConfiguration
|
|
if config.UsesReporting() {
|
|
reportingConfig = setupReporting(logger)
|
|
}
|
|
return ctx,
|
|
SetupResult{
|
|
Logger: logger,
|
|
Configuration: configuration,
|
|
MetricsConfiguration: metricsConfiguration,
|
|
MetricsManager: metricsManager,
|
|
Jp: jmespath.New(configuration),
|
|
KubeClient: client,
|
|
LeaderElectionClient: leaderElectionClient,
|
|
RegistryClient: registryClient,
|
|
ImageVerifyCacheClient: imageVerifyCache,
|
|
RegistrySecretLister: registrySecretLister,
|
|
KyvernoClient: kyvernoClient,
|
|
DynamicClient: dynamicClient,
|
|
ApiServerClient: apiServerClient,
|
|
MetadataClient: metadataClient,
|
|
KyvernoDynamicClient: dClient,
|
|
EventsClient: eventsClient,
|
|
ReportingConfiguration: reportingConfig,
|
|
ResyncPeriod: resyncPeriod,
|
|
},
|
|
shutdown(logger.WithName("shutdown"), sdownMaxProcs, sdownMetrics, sdownTracing, sdownSignals)
|
|
}
|