Documentation ¶
Overview ¶
Package dataplane provides functionality for communicating with and providing configuration to backend dataplane APIs.
Index ¶
- Constants
- func UniqueObjects(reportedObjects []client.Object, resourceFailures []failures.ResourceFailure) []client.Object
- type AddressFinder
- type AddressGetter
- type Client
- type KongClient
- func (c *KongClient) AreKubernetesObjectReportsEnabled() bool
- func (c *KongClient) DBMode() dpconf.DBMode
- func (c *KongClient) DeleteObject(obj client.Object) error
- func (c *KongClient) EnableKubernetesObjectReports(q *status.Queue)
- func (c *KongClient) KubernetesObjectConfigurationStatus(obj client.Object) k8sobj.ConfigurationStatus
- func (c *KongClient) KubernetesObjectIsConfigured(obj client.Object) bool
- func (c *KongClient) Listeners(ctx context.Context) ([]kong.ProxyListener, []kong.StreamListener, error)
- func (c *KongClient) ObjectExists(obj client.Object) (bool, error)
- func (c *KongClient) SetConfigStatusNotifier(n clients.ConfigStatusNotifier)
- func (c *KongClient) Update(ctx context.Context) error
- func (c *KongClient) UpdateObject(obj client.Object) error
- type KongConfigBuilder
- type Synchronizer
- type SynchronizerOption
Constants ¶
const ( // KongConfigurationApplySucceededEventReason defines an event reason to tell the updating of Kong configuration succeeded. KongConfigurationApplySucceededEventReason = "KongConfigurationSucceeded" // KongConfigurationTranslationFailedEventReason defines an event reason used for creating all translation resource failure events. KongConfigurationTranslationFailedEventReason = "KongConfigurationTranslationFailed" // KongConfigurationApplyFailedEventReason defines an event reason used for creating all config apply resource failure events. KongConfigurationApplyFailedEventReason = "KongConfigurationApplyFailed" )
const ( // DefaultSyncSeconds indicates the time.Duration (minimum) that will occur between // updates to the DataplaneClient. // // This default was based on local testing wherein it appeared sub-second updates // to the Admin API could be problematic (or at least operate differently) based on // which storage backend was in use (i.e. "dbless", "postgres"). This is a workaround // for improvements we still need to investigate upstream. // // See Also: https://github.com/Kong/kubernetes-ingress-controller/issues/1398 DefaultSyncSeconds float32 = 3.0 DefaultCacheSyncWaitDuration = 5 * time.Second )
const ( // DefaultTimeoutSeconds indicates the time.Duration allowed for responses to // come back from the backend data-plane API. // // NOTE: the current default is based on observed latency in a CI environment using // the GKE cloud provider with the Kong Admin API. DefaultTimeoutSeconds float32 = 30.0 )
Variables ¶
This section is empty.
Functions ¶
func UniqueObjects ¶
Types ¶
type AddressFinder ¶
type AddressFinder struct {
// contains filtered or unexported fields
}
AddressFinder is a threadsafe metadata object which can provide the current live addresses in use by the dataplane at any point in time.
func NewAddressFinder ¶
func NewAddressFinder() *AddressFinder
NewAddressFinder provides a new AddressFinder which can be used to find the current listening addresses of the data-plane for ingress network traffic.
func (*AddressFinder) GetAddresses ¶
func (a *AddressFinder) GetAddresses(ctx context.Context) ([]string, error)
GetAddresses provides a list of the addresses which the data-plane is listening on for ingress network traffic. Addresses can either be IP addresses or hostnames.
func (*AddressFinder) GetLoadBalancerAddresses ¶
func (a *AddressFinder) GetLoadBalancerAddresses(ctx context.Context) ([]netv1.IngressLoadBalancerIngress, error)
GetLoadBalancerAddresses provides a list of the addresses which the data-plane is listening on for ingress network traffic, but provides the addresses in Kubernetes corev1.LoadBalancerIngress format. Addresses can be IP addresses or hostnames.
func (*AddressFinder) SetGetter ¶
func (a *AddressFinder) SetGetter(getter AddressGetter)
SetGetter provides a callback function that the AddressFinder will use to dynamically retrieve the addresses of the data-plane.
func (*AddressFinder) SetOverrides ¶
func (a *AddressFinder) SetOverrides(addrs []string)
SetOverrides hard codes a specific list of addresses to be the addresses that this finder produces for the data-plane. To disable overrides, call this method again with an empty list.
type AddressGetter ¶
AddressGetter is a function which can dynamically retrieve the list of IPs that the data-plane is listening on for ingress network traffic.
type KongClient ¶
type KongClient struct { // SHAs is a slice is configuration hashes send in last batch send. SHAs []string // contains filtered or unexported fields }
KongClient is a threadsafe high level API client for the Kong data-plane(s) which parses Kubernetes object caches into Kong Admin configurations and sends them as updates to the data-plane(s) (Kong Admin API).
func NewKongClient ¶
func NewKongClient( logger logr.Logger, timeout time.Duration, diagnostic util.ConfigDumpDiagnostic, kongConfig sendconfig.Config, eventRecorder record.EventRecorder, dbMode dpconf.DBMode, clientsProvider clients.AdminAPIClientsProvider, updateStrategyResolver sendconfig.UpdateStrategyResolver, configChangeDetector sendconfig.ConfigurationChangeDetector, kongConfigFetcher configfetcher.LastValidConfigFetcher, parser KongConfigBuilder, cacheStores store.CacheStores, ) (*KongClient, error)
NewKongClient provides a new KongClient object after connecting to the data-plane API and verifying integrity.
func (*KongClient) AreKubernetesObjectReportsEnabled ¶
func (c *KongClient) AreKubernetesObjectReportsEnabled() bool
AreKubernetesObjectReportsEnabled returns true or false whether this client has been configured to report on Kubernetes objects which have been successfully configured for in the data-plane.
func (*KongClient) DBMode ¶
func (c *KongClient) DBMode() dpconf.DBMode
DBMode indicates which database the Kong Gateway is using.
func (*KongClient) DeleteObject ¶
func (c *KongClient) DeleteObject(obj client.Object) error
DeleteObject accepts a Kubernetes controller-runtime client.Object and removes it from the configuration cache. The delete action will asynchronously be converted to Kong DSL and applied to the Kong Admin API. A status will later be added to the object whether the configuration update succeeds or fails.
under the hood the cache implementation will ignore deletions on objects that are not present in the cache, so in those cases this is a no-op.
func (*KongClient) EnableKubernetesObjectReports ¶
func (c *KongClient) EnableKubernetesObjectReports(q *status.Queue)
EnableKubernetesObjectReports turns on reporting for Kubernetes objects which are configured as part of Update() operations. Enabling this makes it possible to use ObjectConfigured(obj) to determine whether an object has successfully been configured for on the data-plane.
func (*KongClient) KubernetesObjectConfigurationStatus ¶
func (c *KongClient) KubernetesObjectConfigurationStatus(obj client.Object) k8sobj.ConfigurationStatus
KubernetesObjectConfigurationStatus reports the status of applying provided object's configuration to the data-plane.
func (*KongClient) KubernetesObjectIsConfigured ¶
func (c *KongClient) KubernetesObjectIsConfigured(obj client.Object) bool
KubernetesObjectIsConfigured reports whether the provided object has active configuration for itself successfully applied to the data-plane.
func (*KongClient) Listeners ¶
func (c *KongClient) Listeners(ctx context.Context) ([]kong.ProxyListener, []kong.StreamListener, error)
Listeners retrieves the currently configured listeners from the underlying proxy so that callers can gather this metadata to know which ports and protocols are in use by the proxy.
func (*KongClient) ObjectExists ¶
func (c *KongClient) ObjectExists(obj client.Object) (bool, error)
ObjectExists indicates whether or not any version of the provided object is already present in the proxy.
func (*KongClient) SetConfigStatusNotifier ¶
func (c *KongClient) SetConfigStatusNotifier(n clients.ConfigStatusNotifier)
SetConfigStatusNotifier sets a notifier which notifies subscribers about configuration sending results. Currently it is used for uploading the node status to konnect control plane.
func (*KongClient) Update ¶
func (c *KongClient) Update(ctx context.Context) error
Update parses the Cache present in the client and converts current Kubernetes state into Kong objects and state, and then ships the resulting configuration to the data-plane (Kong Admin API).
func (*KongClient) UpdateObject ¶
func (c *KongClient) UpdateObject(obj client.Object) error
UpdateObject accepts a Kubernetes controller-runtime client.Object and adds/updates that to the configuration cache. It will be asynchronously converted into the upstream Kong DSL and applied to the Kong Admin API. A status will later be added to the object whether the configuration update succeeds or fails.
type KongConfigBuilder ¶
type KongConfigBuilder interface {
BuildKongConfig() translator.KongConfigBuildingResult
}
KongConfigBuilder builds a Kong configuration from a Kubernetes object cache.
type Synchronizer ¶
type Synchronizer struct {
// contains filtered or unexported fields
}
Synchronizer is a threadsafe object which starts a goroutine to updates the data-plane at regular intervals.
func NewSynchronizer ¶
func NewSynchronizer(logger logr.Logger, client Client, opts ...SynchronizerOption) (*Synchronizer, error)
NewSynchronizer will provide a new Synchronizer object with a specified stagger time for data-plane updates to occur. Note that this starts some background goroutines and the caller is resonsible for marking the provided context.Context as "Done()" to shut down the background routines.
func (*Synchronizer) IsReady ¶
func (p *Synchronizer) IsReady() bool
IsReady indicates whether the synchronizer is actively able to synchronize configuration to the dataplane. It's similar to IsRunning() but reports on whether configuration can actually be successful and is also used as part of a controller-runtime Runnable interface to wait for readiness before starting controllers.
func (*Synchronizer) IsRunning ¶
func (p *Synchronizer) IsRunning() bool
IsRunning informs the caller whether the synchronization server is running.
func (*Synchronizer) NeedLeaderElection ¶
func (p *Synchronizer) NeedLeaderElection() bool
NeedLeaderElection implements the controller-runtime Runnable interface to inform the controller manager whether leadership election is needed, which is always true in our case.
func (*Synchronizer) Start ¶
func (p *Synchronizer) Start(ctx context.Context) error
Start starts the goroutine synchronization server that will perform an Update() on the provided dataplane.Client according to the provided stagger time, or using the DefaultSyncSeconds if not otherwise provided.
To stop the server, the provided context must be Done().
type SynchronizerOption ¶
type SynchronizerOption func(*Synchronizer)
func WithInitCacheSyncDuration ¶
func WithInitCacheSyncDuration(period time.Duration) SynchronizerOption
WithInitCacheSyncDuration returns a SynchronizerOption which sets the initial wait period.
func WithStagger ¶
func WithStagger(period time.Duration) SynchronizerOption
WithStagger returns a SynchronizerOption which sets the stagger period.