-
Notifications
You must be signed in to change notification settings - Fork 43
/
actuator.go
43 lines (36 loc) · 1.45 KB
/
actuator.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
// SPDX-FileCopyrightText: 2024 SAP SE or an SAP affiliate company and Gardener contributors
//
// SPDX-License-Identifier: Apache-2.0
package controller
import (
extensionscontroller "github.com/gardener/gardener/extensions/pkg/controller"
"github.com/gardener/gardener/extensions/pkg/controller/network"
gardenerkubernetes "github.com/gardener/gardener/pkg/client/kubernetes"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/client-go/rest"
"sigs.k8s.io/controller-runtime/pkg/client"
"sigs.k8s.io/controller-runtime/pkg/manager"
calicov1alpha1 "github.com/gardener/gardener-extension-networking-calico/pkg/apis/calico/v1alpha1"
)
var (
// StatusTypeMeta is the TypeMeta of Calico Status
StatusTypeMeta = metav1.TypeMeta{
APIVersion: calicov1alpha1.SchemeGroupVersion.String(),
Kind: "NetworkStatus",
}
)
type actuator struct {
restConfig *rest.Config
client client.Client
chartRendererFactory extensionscontroller.ChartRendererFactory
chartApplier gardenerkubernetes.ChartApplier
}
// NewActuator creates a new Actuator that updates the status of the handled Network resources.
func NewActuator(mgr manager.Manager, chartApplier gardenerkubernetes.ChartApplier, chartRendererFactory extensionscontroller.ChartRendererFactory) network.Actuator {
return &actuator{
client: mgr.GetClient(),
restConfig: mgr.GetConfig(),
chartApplier: chartApplier,
chartRendererFactory: chartRendererFactory,
}
}