/
btp_operator_overrides.go
52 lines (44 loc) · 2.03 KB
/
btp_operator_overrides.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
package upgrade_kyma
import (
"time"
"github.com/kyma-project/control-plane/components/kyma-environment-broker/internal"
"github.com/kyma-project/control-plane/components/kyma-environment-broker/internal/process"
"github.com/kyma-project/control-plane/components/kyma-environment-broker/internal/storage"
"github.com/sirupsen/logrus"
)
var ConfigMapGetter internal.ClusterIDGetter = internal.GetClusterIDWithKubeconfig
type BTPOperatorOverridesStep struct {
operationManager *process.UpgradeKymaOperationManager
}
func NewBTPOperatorOverridesStep(os storage.Operations) *BTPOperatorOverridesStep {
return &BTPOperatorOverridesStep{
operationManager: process.NewUpgradeKymaOperationManager(os),
}
}
func (s *BTPOperatorOverridesStep) Name() string {
return "BTPOperatorOverrides"
}
func (s *BTPOperatorOverridesStep) Run(operation internal.UpgradeKymaOperation, log logrus.FieldLogger) (internal.UpgradeKymaOperation, time.Duration, error) {
if !operation.InputCreator.Configuration().ContainsAdditionalComponent(internal.BTPOperatorComponentName) {
log.Infof("BTP operator is not in the list of additional components, skipping")
return operation, 0, nil
}
clusterID := operation.InstanceDetails.ServiceManagerClusterID
if clusterID == "" {
var err error
if clusterID, err = ConfigMapGetter(operation.InstanceDetails.Kubeconfig); err != nil {
return s.operationManager.OperationFailed(operation, "failed to create BTP Operator input", err, log)
}
}
creds := operation.ProvisioningParameters.ErsContext.SMOperatorCredentials
overrides := internal.GetBTPOperatorProvisioningOverrides(creds, clusterID)
operation.InputCreator.AppendOverrides(internal.BTPOperatorComponentName, overrides)
operation.InputCreator.EnableOptionalComponent(internal.BTPOperatorComponentName)
if clusterID == operation.InstanceDetails.ServiceManagerClusterID {
return operation, 0, nil
}
f := func(op *internal.UpgradeKymaOperation) {
op.InstanceDetails.ServiceManagerClusterID = clusterID
}
return s.operationManager.UpdateOperation(operation, f, log)
}