This repository has been archived by the owner on Nov 30, 2023. It is now read-only.
/
resource.go
87 lines (73 loc) · 2.4 KB
/
resource.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
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
package masters
import (
"context"
providerv1alpha1 "github.com/giantswarm/apiextensions/v6/pkg/apis/provider/v1alpha1"
"github.com/giantswarm/k8sclient/v7/pkg/k8sclient"
"github.com/giantswarm/microerror"
"github.com/giantswarm/tenantcluster/v6/pkg/tenantcluster"
"k8s.io/client-go/rest"
"sigs.k8s.io/controller-runtime/pkg/client"
"github.com/giantswarm/azure-operator/v5/pkg/handler/nodes"
"github.com/giantswarm/azure-operator/v5/service/controller/internal/vmsku"
"github.com/giantswarm/azure-operator/v5/service/controller/key"
)
const (
Name = "masters"
)
type Config struct {
nodes.Config
CtrlClient client.Client
TenantRestConfigProvider *tenantcluster.TenantCluster
VMSKU *vmsku.VMSKUs
}
type Resource struct {
nodes.Resource
ctrlClient client.Client
tenantRestConfigProvider *tenantcluster.TenantCluster
vmSku *vmsku.VMSKUs
}
func New(config Config) (*Resource, error) {
if config.CtrlClient == nil {
return nil, microerror.Maskf(invalidConfigError, "%T.CtrlClient must not be empty", config)
}
if config.TenantRestConfigProvider == nil {
return nil, microerror.Maskf(invalidConfigError, "%T.TenantRestConfigProvider must not be empty", config)
}
if config.VMSKU == nil {
return nil, microerror.Maskf(invalidConfigError, "%T.VMSKU must not be empty", config)
}
config.Name = Name
nodes, err := nodes.New(config.Config)
if err != nil {
return nil, microerror.Mask(err)
}
r := &Resource{
Resource: *nodes,
ctrlClient: config.CtrlClient,
tenantRestConfigProvider: config.TenantRestConfigProvider,
vmSku: config.VMSKU,
}
stateMachine := r.createStateMachine()
r.SetStateMachine(stateMachine)
return r, nil
}
func (r *Resource) Name() string {
return r.Resource.Name()
}
func (r *Resource) getTenantClusterClient(ctx context.Context, azureConfig *providerv1alpha1.AzureConfig) (client.Client, error) {
var k8sClient k8sclient.Interface
{
restConfig, err := r.tenantRestConfigProvider.NewRestConfig(ctx, key.ClusterID(azureConfig), key.ClusterAPIEndpoint(*azureConfig))
if err != nil {
return nil, microerror.Mask(err)
}
k8sClient, err = k8sclient.NewClients(k8sclient.ClientsConfig{
Logger: r.Logger,
RestConfig: rest.CopyConfig(restConfig),
})
if err != nil {
return nil, microerror.Mask(err)
}
}
return k8sClient.CtrlClient(), nil
}