Documentation ¶
Overview ¶
Package remote implements remote controllers.
Index ¶
- func DefaultClusterAPIUserAgent(sourceName string) string
- func NewClusterClient(ctx context.Context, sourceName string, c client.Client, ...) (client.Client, error)
- func RESTConfig(ctx context.Context, sourceName string, c client.Reader, ...) (*restclient.Config, error)
- type ClusterCacheReconciler
- type ClusterCacheTracker
- type ClusterCacheTrackerOptions
- type ClusterClientGetter
- type WatchInput
- type Watcher
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func DefaultClusterAPIUserAgent ¶ added in v0.4.0
DefaultClusterAPIUserAgent returns a User-Agent string built from static global vars.
Types ¶
type ClusterCacheReconciler ¶ added in v0.3.6
type ClusterCacheReconciler struct { Log logr.Logger Client client.Client Tracker *ClusterCacheTracker }
ClusterCacheReconciler is responsible for stopping remote cluster caches when the cluster for the remote cache is being deleted.
func (*ClusterCacheReconciler) Reconcile ¶ added in v0.3.6
func (r *ClusterCacheReconciler) Reconcile(ctx context.Context, req reconcile.Request) (reconcile.Result, error)
Reconcile reconciles Clusters and removes ClusterCaches for any Cluster that cannot be retrieved from the management cluster.
func (*ClusterCacheReconciler) SetupWithManager ¶ added in v0.3.7
func (r *ClusterCacheReconciler) SetupWithManager(ctx context.Context, mgr ctrl.Manager, options controller.Options) error
type ClusterCacheTracker ¶ added in v0.3.6
type ClusterCacheTracker struct {
// contains filtered or unexported fields
}
ClusterCacheTracker manages client caches for workload clusters.
func NewClusterCacheTracker ¶ added in v0.3.6
func NewClusterCacheTracker(manager ctrl.Manager, options ClusterCacheTrackerOptions) (*ClusterCacheTracker, error)
NewClusterCacheTracker creates a new ClusterCacheTracker.
func NewTestClusterCacheTracker ¶ added in v0.3.11
func NewTestClusterCacheTracker(log logr.Logger, cl client.Client, scheme *runtime.Scheme, objKey client.ObjectKey, watchObjects ...string) *ClusterCacheTracker
NewTestClusterCacheTracker creates a new fake ClusterCacheTracker that can be used by unit tests with fake client.
func (*ClusterCacheTracker) GetClient ¶ added in v0.3.7
func (t *ClusterCacheTracker) GetClient(ctx context.Context, cluster client.ObjectKey) (client.Client, error)
GetClient returns a cached client for the given cluster.
func (*ClusterCacheTracker) Watch ¶ added in v0.3.6
func (t *ClusterCacheTracker) Watch(ctx context.Context, input WatchInput) error
Watch watches a remote cluster for resource events. If the watch already exists based on input.Name, this is a no-op.
type ClusterCacheTrackerOptions ¶ added in v0.4.0
type ClusterCacheTrackerOptions struct { // Log is the logger used throughout the lifecycle of caches. // Defaults to a no-op logger if it's not set. Log logr.Logger // ClientUncachedObjects instructs the Client to never cache the following objects, // it'll instead query the API server directly. // Defaults to never caching ConfigMap and Secret if not set. ClientUncachedObjects []client.Object }
ClusterCacheTrackerOptions defines options to configure a ClusterCacheTracker.
type ClusterClientGetter ¶ added in v0.3.0
type ClusterClientGetter func(ctx context.Context, sourceName string, c client.Client, cluster client.ObjectKey) (client.Client, error)
ClusterClientGetter returns a new remote client.
type WatchInput ¶ added in v0.3.6
type WatchInput struct { // Name represents a unique watch request for the specified Cluster. Name string // Cluster is the key for the remote cluster. Cluster client.ObjectKey // Watcher is the watcher (controller) whose Reconcile() function will be called for events. Watcher Watcher // Kind is the type of resource to watch. Kind client.Object // EventHandler contains the event handlers to invoke for resource events. EventHandler handler.EventHandler // Predicates is used to filter resource events. Predicates []predicate.Predicate }
WatchInput specifies the parameters used to establish a new watch for a remote cluster.
type Watcher ¶ added in v0.3.6
type Watcher interface { // Watch watches src for changes, sending events to eventHandler if they pass predicates. Watch(src source.Source, eventHandler handler.EventHandler, predicates ...predicate.Predicate) error }
Watcher is a scoped-down interface from Controller that only knows how to watch.