2022-09-05 09:06:08 +02:00
/ *
Copyright ( c ) Edgeless Systems GmbH
SPDX - License - Identifier : AGPL - 3.0 - only
* /
2022-08-29 16:49:44 +02:00
package cmd
import (
"context"
2023-01-04 13:55:10 +01:00
"errors"
2022-12-19 16:52:15 +01:00
"fmt"
2023-05-22 13:31:20 +02:00
"path/filepath"
"strings"
2022-12-19 16:52:15 +01:00
"time"
2022-08-29 16:49:44 +02:00
2023-05-03 11:11:53 +02:00
"github.com/edgelesssys/constellation/v2/cli/internal/clusterid"
2023-01-04 13:55:10 +01:00
"github.com/edgelesssys/constellation/v2/cli/internal/helm"
2023-03-30 16:13:14 +02:00
"github.com/edgelesssys/constellation/v2/cli/internal/kubernetes"
2023-05-22 13:31:20 +02:00
"github.com/edgelesssys/constellation/v2/cli/internal/terraform"
"github.com/edgelesssys/constellation/v2/cli/internal/upgrade"
2023-06-07 16:16:32 +02:00
"github.com/edgelesssys/constellation/v2/internal/api/attestationconfigapi"
2023-06-09 15:41:02 +02:00
"github.com/edgelesssys/constellation/v2/internal/attestation/variant"
2023-03-24 17:07:14 +01:00
"github.com/edgelesssys/constellation/v2/internal/cloud/cloudprovider"
2023-02-28 10:23:09 +01:00
"github.com/edgelesssys/constellation/v2/internal/compatibility"
2022-09-21 13:47:57 +02:00
"github.com/edgelesssys/constellation/v2/internal/config"
2023-05-03 11:11:53 +02:00
"github.com/edgelesssys/constellation/v2/internal/constants"
2022-09-21 13:47:57 +02:00
"github.com/edgelesssys/constellation/v2/internal/file"
2023-05-23 09:17:27 +02:00
"github.com/edgelesssys/constellation/v2/internal/imagefetcher"
2023-06-23 12:08:30 +02:00
"github.com/edgelesssys/constellation/v2/internal/role"
2023-06-05 09:13:02 +02:00
"github.com/edgelesssys/constellation/v2/internal/versions"
2022-08-29 16:49:44 +02:00
"github.com/spf13/afero"
"github.com/spf13/cobra"
2023-03-14 18:34:58 +01:00
corev1 "k8s.io/api/core/v1"
2022-08-29 16:49:44 +02:00
)
2023-02-01 10:56:47 +01:00
func newUpgradeApplyCmd ( ) * cobra . Command {
2022-08-29 16:49:44 +02:00
cmd := & cobra . Command {
2023-02-09 15:54:12 +01:00
Use : "apply" ,
2023-02-01 10:56:47 +01:00
Short : "Apply an upgrade to a Constellation cluster" ,
Long : "Apply an upgrade to a Constellation cluster by applying the chosen configuration." ,
2022-08-29 16:49:44 +02:00
Args : cobra . NoArgs ,
2023-02-01 10:56:47 +01:00
RunE : runUpgradeApply ,
2022-08-29 16:49:44 +02:00
}
2023-01-17 14:01:56 +01:00
cmd . Flags ( ) . BoolP ( "yes" , "y" , false , "run upgrades without further confirmation\n" +
2023-03-14 18:34:58 +01:00
"WARNING: might delete your resources in case you are using cert-manager in your cluster. Please read the docs.\n" +
"WARNING: might unintentionally overwrite measurements in the running cluster." )
2023-06-06 15:22:06 +02:00
cmd . Flags ( ) . Duration ( "timeout" , 5 * time . Minute , "change helm upgrade timeout\n" +
2023-02-01 11:23:57 +01:00
"Might be useful for slow connections or big clusters." )
2022-12-19 16:52:15 +01:00
if err := cmd . Flags ( ) . MarkHidden ( "timeout" ) ; err != nil {
panic ( err )
}
2022-08-29 16:49:44 +02:00
return cmd
}
2023-03-20 11:03:36 +01:00
func runUpgradeApply ( cmd * cobra . Command , _ [ ] string ) error {
2022-12-19 16:52:15 +01:00
log , err := newCLILogger ( cmd )
if err != nil {
return fmt . Errorf ( "creating logger: %w" , err )
}
defer log . Sync ( )
2022-08-29 16:49:44 +02:00
fileHandler := file . NewHandler ( afero . NewOsFs ( ) )
2023-06-21 09:22:32 +02:00
upgrader , err := kubernetes . NewUpgrader ( cmd . Context ( ) , cmd . OutOrStdout ( ) , log , kubernetes . UpgradeCmdKindApply )
2022-08-29 16:49:44 +02:00
if err != nil {
return err
}
2023-06-01 13:55:46 +02:00
imagefetcher := imagefetcher . New ( )
2023-06-07 16:16:32 +02:00
configFetcher := attestationconfigapi . NewFetcher ( )
2023-05-22 13:31:20 +02:00
2023-06-01 13:55:46 +02:00
applyCmd := upgradeApplyCmd { upgrader : upgrader , log : log , imageFetcher : imagefetcher , configFetcher : configFetcher }
2023-03-03 09:38:23 +01:00
return applyCmd . upgradeApply ( cmd , fileHandler )
2022-08-29 16:49:44 +02:00
}
2023-02-09 15:54:12 +01:00
type upgradeApplyCmd struct {
2023-06-01 13:55:46 +02:00
upgrader cloudUpgrader
imageFetcher imageFetcher
2023-06-07 16:16:32 +02:00
configFetcher attestationconfigapi . Fetcher
2023-06-01 13:55:46 +02:00
log debugLog
2023-02-09 15:54:12 +01:00
}
2023-03-03 09:38:23 +01:00
func ( u * upgradeApplyCmd ) upgradeApply ( cmd * cobra . Command , fileHandler file . Handler ) error {
2023-02-01 10:56:47 +01:00
flags , err := parseUpgradeApplyFlags ( cmd )
2022-08-29 16:49:44 +02:00
if err != nil {
2023-01-04 13:55:10 +01:00
return fmt . Errorf ( "parsing flags: %w" , err )
2022-08-29 16:49:44 +02:00
}
2023-06-01 13:55:46 +02:00
conf , err := config . New ( fileHandler , flags . configPath , u . configFetcher , flags . force )
2023-02-07 12:56:25 +01:00
var configValidationErr * config . ValidationError
if errors . As ( err , & configValidationErr ) {
cmd . PrintErrln ( configValidationErr . LongMessage ( ) )
}
2022-08-29 16:49:44 +02:00
if err != nil {
2023-02-07 12:56:25 +01:00
return err
2022-08-29 16:49:44 +02:00
}
2023-06-05 09:13:02 +02:00
if err := handleInvalidK8sPatchVersion ( cmd , conf . KubernetesVersion , flags . yes ) ; err != nil {
return err
}
2023-05-03 11:11:53 +02:00
var idFile clusterid . File
if err := fileHandler . ReadJSON ( constants . ClusterIDsFileName , & idFile ) ; err != nil {
return fmt . Errorf ( "reading cluster ID file: %w" , err )
}
conf . UpdateMAAURL ( idFile . AttestationURL )
// If an image upgrade was just executed there won't be a diff. The function will return nil in that case.
if err := u . upgradeAttestConfigIfDiff ( cmd , conf . GetAttestationConfig ( ) , flags ) ; err != nil {
return fmt . Errorf ( "upgrading measurements: %w" , err )
}
2023-06-01 13:55:46 +02:00
if err := u . migrateTerraform ( cmd , fileHandler , u . imageFetcher , conf , flags ) ; err != nil {
2023-05-22 13:31:20 +02:00
return fmt . Errorf ( "performing Terraform migrations: %w" , err )
}
2023-05-19 13:57:31 +02:00
if conf . GetProvider ( ) == cloudprovider . Azure || conf . GetProvider ( ) == cloudprovider . GCP || conf . GetProvider ( ) == cloudprovider . AWS {
2023-06-30 16:46:05 +02:00
var upgradeErr * compatibility . InvalidUpgradeError
2023-07-11 18:15:29 +02:00
err = u . handleServiceUpgrade ( cmd , conf , idFile , flags )
2023-03-24 17:07:14 +01:00
switch {
2023-06-30 16:46:05 +02:00
case errors . As ( err , & upgradeErr ) :
2023-03-24 17:07:14 +01:00
cmd . PrintErrln ( err )
case err != nil :
return fmt . Errorf ( "upgrading services: %w" , err )
}
2022-12-19 16:52:15 +01:00
2023-06-21 15:49:42 +02:00
err = u . upgrader . UpgradeNodeVersion ( cmd . Context ( ) , conf , flags . force )
2023-03-24 17:07:14 +01:00
switch {
2023-03-30 16:13:14 +02:00
case errors . Is ( err , kubernetes . ErrInProgress ) :
2023-03-24 17:07:14 +01:00
cmd . PrintErrln ( "Skipping image and Kubernetes upgrades. Another upgrade is in progress." )
2023-06-30 16:46:05 +02:00
case errors . As ( err , & upgradeErr ) :
2023-03-24 17:07:14 +01:00
cmd . PrintErrln ( err )
case err != nil :
return fmt . Errorf ( "upgrading NodeVersion: %w" , err )
}
} else {
2023-05-19 13:57:31 +02:00
cmd . PrintErrln ( "WARNING: Skipping service and image upgrades, which are currently only supported for AWS, Azure, and GCP." )
2023-02-09 15:54:12 +01:00
}
2023-03-14 18:34:58 +01:00
return nil
}
2023-05-22 13:31:20 +02:00
// migrateTerraform checks if the Constellation version the cluster is being upgraded to requires a migration
// of cloud resources with Terraform. If so, the migration is performed.
func ( u * upgradeApplyCmd ) migrateTerraform ( cmd * cobra . Command , file file . Handler , fetcher imageFetcher , conf * config . Config , flags upgradeApplyFlags ) error {
u . log . Debugf ( "Planning Terraform migrations" )
if err := u . upgrader . CheckTerraformMigrations ( file ) ; err != nil {
return fmt . Errorf ( "checking workspace: %w" , err )
}
2023-06-27 13:12:50 +02:00
// TODO(AB#3248): Remove this migration after we can assume that all existing clusters have been migrated.
var awsZone string
if conf . GetProvider ( ) == cloudprovider . AWS {
awsZone = conf . Provider . AWS . Zone
}
manualMigrations := terraformMigrationAWSNodeGroups ( conf . GetProvider ( ) , awsZone )
for _ , migration := range manualMigrations {
u . log . Debugf ( "Adding manual Terraform migration: %s" , migration . DisplayName )
u . upgrader . AddManualStateMigration ( migration )
}
2023-06-27 11:27:50 +02:00
vars , err := parseTerraformUpgradeVars ( cmd , conf , fetcher )
2023-05-22 13:31:20 +02:00
if err != nil {
return fmt . Errorf ( "parsing upgrade variables: %w" , err )
}
u . log . Debugf ( "Using Terraform variables:\n%v" , vars )
opts := upgrade . TerraformUpgradeOptions {
LogLevel : flags . terraformLogLevel ,
CSP : conf . GetProvider ( ) ,
Vars : vars ,
OutputFile : constants . TerraformMigrationOutputFile ,
}
// Check if there are any Terraform migrations to apply
hasDiff , err := u . upgrader . PlanTerraformMigrations ( cmd . Context ( ) , opts )
if err != nil {
return fmt . Errorf ( "planning terraform migrations: %w" , err )
}
if hasDiff {
// If there are any Terraform migrations to apply, ask for confirmation
2023-06-19 13:02:01 +02:00
fmt . Fprintln ( cmd . OutOrStdout ( ) , "The upgrade requires a migration of Constellation cloud resources by applying an updated Terraform template. Please manually review the suggested changes below." )
2023-05-22 13:31:20 +02:00
if ! flags . yes {
ok , err := askToConfirm ( cmd , "Do you want to apply the Terraform migrations?" )
if err != nil {
return fmt . Errorf ( "asking for confirmation: %w" , err )
}
if ! ok {
cmd . Println ( "Aborting upgrade." )
if err := u . upgrader . CleanUpTerraformMigrations ( file ) ; err != nil {
return fmt . Errorf ( "cleaning up workspace: %w" , err )
}
return fmt . Errorf ( "aborted by user" )
}
}
u . log . Debugf ( "Applying Terraform migrations" )
err := u . upgrader . ApplyTerraformMigrations ( cmd . Context ( ) , file , opts )
if err != nil {
return fmt . Errorf ( "applying terraform migrations: %w" , err )
}
cmd . Printf ( "Terraform migrations applied successfully and output written to: %s\n" +
"A backup of the pre-upgrade Terraform state has been written to: %s\n" ,
opts . OutputFile , filepath . Join ( constants . UpgradeDir , constants . TerraformUpgradeBackupDir ) )
} else {
u . log . Debugf ( "No Terraform diff detected" )
}
return nil
}
2023-06-21 09:22:32 +02:00
// parseTerraformUpgradeVars parses the variables required to execute the Terraform script with.
2023-06-27 11:27:50 +02:00
func parseTerraformUpgradeVars ( cmd * cobra . Command , conf * config . Config , fetcher imageFetcher ) ( terraform . Variables , error ) {
2023-05-22 13:31:20 +02:00
// Fetch variables to execute Terraform script with
2023-05-23 09:17:27 +02:00
provider := conf . GetProvider ( )
attestationVariant := conf . GetAttestationConfig ( ) . GetVariant ( )
region := conf . GetRegion ( )
imageRef , err := fetcher . FetchReference ( cmd . Context ( ) , provider , attestationVariant , conf . Image , region )
2023-05-22 13:31:20 +02:00
if err != nil {
2023-06-27 11:27:50 +02:00
return nil , fmt . Errorf ( "fetching image reference: %w" , err )
2023-05-22 13:31:20 +02:00
}
switch conf . GetProvider ( ) {
case cloudprovider . AWS :
vars := & terraform . AWSClusterVariables {
2023-06-23 17:19:43 +02:00
Name : conf . Name ,
NodeGroups : map [ string ] terraform . AWSNodeGroup {
"control_plane_default" : {
Role : role . ControlPlane . TFString ( ) ,
StateDiskSizeGB : conf . StateDiskSizeGB ,
Zone : conf . Provider . AWS . Zone ,
InstanceType : conf . Provider . AWS . InstanceType ,
DiskType : conf . Provider . AWS . StateDiskType ,
} ,
"worker_default" : {
Role : role . Worker . TFString ( ) ,
StateDiskSizeGB : conf . StateDiskSizeGB ,
Zone : conf . Provider . AWS . Zone ,
InstanceType : conf . Provider . AWS . InstanceType ,
DiskType : conf . Provider . AWS . StateDiskType ,
} ,
} ,
2023-05-22 13:31:20 +02:00
Region : conf . Provider . AWS . Region ,
Zone : conf . Provider . AWS . Zone ,
AMIImageID : imageRef ,
IAMProfileControlPlane : conf . Provider . AWS . IAMProfileControlPlane ,
IAMProfileWorkerNodes : conf . Provider . AWS . IAMProfileWorkerNodes ,
Debug : conf . IsDebugCluster ( ) ,
}
2023-06-27 11:27:50 +02:00
return vars , nil
2023-05-22 13:31:20 +02:00
case cloudprovider . Azure :
// Azure Terraform provider is very strict about it's casing
imageRef = strings . Replace ( imageRef , "CommunityGalleries" , "communityGalleries" , 1 )
imageRef = strings . Replace ( imageRef , "Images" , "images" , 1 )
imageRef = strings . Replace ( imageRef , "Versions" , "versions" , 1 )
vars := & terraform . AzureClusterVariables {
2023-06-22 16:53:40 +02:00
Name : conf . Name ,
2023-05-22 13:31:20 +02:00
ResourceGroup : conf . Provider . Azure . ResourceGroup ,
UserAssignedIdentity : conf . Provider . Azure . UserAssignedIdentity ,
ImageID : imageRef ,
2023-06-22 16:53:40 +02:00
NodeGroups : map [ string ] terraform . AzureNodeGroup {
"control_plane_default" : {
Role : "control-plane" ,
InstanceType : conf . Provider . Azure . InstanceType ,
DiskSizeGB : conf . StateDiskSizeGB ,
DiskType : conf . Provider . Azure . StateDiskType ,
} ,
"worker_default" : {
Role : "worker" ,
InstanceType : conf . Provider . Azure . InstanceType ,
DiskSizeGB : conf . StateDiskSizeGB ,
DiskType : conf . Provider . Azure . StateDiskType ,
} ,
} ,
Location : conf . Provider . Azure . Location ,
SecureBoot : conf . Provider . Azure . SecureBoot ,
CreateMAA : toPtr ( conf . GetAttestationConfig ( ) . GetVariant ( ) . Equal ( variant . AzureSEVSNP { } ) ) ,
Debug : toPtr ( conf . IsDebugCluster ( ) ) ,
2023-05-22 13:31:20 +02:00
}
2023-06-27 11:27:50 +02:00
return vars , nil
2023-05-22 13:31:20 +02:00
case cloudprovider . GCP :
vars := & terraform . GCPClusterVariables {
2023-06-19 13:02:01 +02:00
Name : conf . Name ,
NodeGroups : map [ string ] terraform . GCPNodeGroup {
"control_plane_default" : {
2023-06-23 12:08:30 +02:00
Role : role . ControlPlane . TFString ( ) ,
2023-06-19 13:02:01 +02:00
StateDiskSizeGB : conf . StateDiskSizeGB ,
Zone : conf . Provider . GCP . Zone ,
InstanceType : conf . Provider . GCP . InstanceType ,
DiskType : conf . Provider . GCP . StateDiskType ,
} ,
"worker_default" : {
2023-06-23 12:08:30 +02:00
Role : role . Worker . TFString ( ) ,
2023-06-19 13:02:01 +02:00
StateDiskSizeGB : conf . StateDiskSizeGB ,
Zone : conf . Provider . GCP . Zone ,
InstanceType : conf . Provider . GCP . InstanceType ,
DiskType : conf . Provider . GCP . StateDiskType ,
} ,
} ,
Project : conf . Provider . GCP . Project ,
Region : conf . Provider . GCP . Region ,
Zone : conf . Provider . GCP . Zone ,
ImageID : imageRef ,
Debug : conf . IsDebugCluster ( ) ,
2023-05-22 13:31:20 +02:00
}
2023-06-27 11:27:50 +02:00
return vars , nil
2023-05-22 13:31:20 +02:00
default :
2023-06-27 11:27:50 +02:00
return nil , fmt . Errorf ( "unsupported provider: %s" , conf . GetProvider ( ) )
2023-05-22 13:31:20 +02:00
}
}
2023-06-05 09:13:02 +02:00
// handleInvalidK8sPatchVersion checks if the Kubernetes patch version is supported and asks for confirmation if not.
func handleInvalidK8sPatchVersion ( cmd * cobra . Command , version string , yes bool ) error {
_ , err := versions . NewValidK8sVersion ( version , true )
valid := err == nil
if ! valid && ! yes {
confirmed , err := askToConfirm ( cmd , fmt . Sprintf ( "WARNING: The Kubernetes patch version %s is not supported. If you continue, Kubernetes upgrades will be skipped. Do you want to continue anyway?" , version ) )
if err != nil {
return fmt . Errorf ( "asking for confirmation: %w" , err )
}
if ! confirmed {
return fmt . Errorf ( "aborted by user" )
}
}
return nil
}
2023-05-22 13:31:20 +02:00
type imageFetcher interface {
2023-05-23 09:17:27 +02:00
FetchReference ( ctx context . Context ,
provider cloudprovider . Provider , attestationVariant variant . Variant ,
image , region string ,
) ( string , error )
2023-05-22 13:31:20 +02:00
}
2023-05-03 11:11:53 +02:00
// upgradeAttestConfigIfDiff checks if the locally configured measurements are different from the cluster's measurements.
2023-03-14 18:34:58 +01:00
// If so the function will ask the user to confirm (if --yes is not set) and upgrade the measurements only.
2023-05-03 11:11:53 +02:00
func ( u * upgradeApplyCmd ) upgradeAttestConfigIfDiff ( cmd * cobra . Command , newConfig config . AttestationCfg , flags upgradeApplyFlags ) error {
clusterAttestationConfig , _ , err := u . upgrader . GetClusterAttestationConfig ( cmd . Context ( ) , newConfig . GetVariant ( ) )
2023-07-10 14:03:45 +02:00
if err != nil {
return fmt . Errorf ( "getting cluster attestation config: %w" , err )
2023-03-14 18:34:58 +01:00
}
2023-07-10 14:03:45 +02:00
// If the current config is equal, or there is an error when comparing the configs, we skip the upgrade.
2023-07-12 11:53:00 +02:00
equal , err := newConfig . EqualTo ( clusterAttestationConfig )
if err != nil {
2023-07-10 14:03:45 +02:00
return fmt . Errorf ( "comparing attestation configs: %w" , err )
2023-03-14 18:34:58 +01:00
}
2023-07-12 11:53:00 +02:00
if equal {
return nil
}
2023-03-14 18:34:58 +01:00
if ! flags . yes {
2023-05-03 11:11:53 +02:00
ok , err := askToConfirm ( cmd , "You are about to change your cluster's attestation config. Are you sure you want to continue?" )
2023-03-14 18:34:58 +01:00
if err != nil {
return fmt . Errorf ( "asking for confirmation: %w" , err )
}
if ! ok {
2023-05-03 11:11:53 +02:00
cmd . Println ( "Skipping upgrade." )
2023-03-14 18:34:58 +01:00
return nil
}
}
2023-05-03 11:11:53 +02:00
if err := u . upgrader . UpdateAttestationConfig ( cmd . Context ( ) , newConfig ) ; err != nil {
return fmt . Errorf ( "updating attestation config: %w" , err )
2023-03-14 18:34:58 +01:00
}
2023-02-09 15:54:12 +01:00
return nil
2023-02-01 11:23:57 +01:00
}
2023-07-11 18:15:29 +02:00
func ( u * upgradeApplyCmd ) handleServiceUpgrade ( cmd * cobra . Command , conf * config . Config , idFile clusterid . File , flags upgradeApplyFlags ) error {
err := u . upgrader . UpgradeHelmServices ( cmd . Context ( ) , conf , idFile , flags . upgradeTimeout , helm . DenyDestructive , flags . force )
2023-02-01 11:23:57 +01:00
if errors . Is ( err , helm . ErrConfirmationMissing ) {
if ! flags . yes {
cmd . PrintErrln ( "WARNING: Upgrading cert-manager will destroy all custom resources you have manually created that are based on the current version of cert-manager." )
ok , askErr := askToConfirm ( cmd , "Do you want to upgrade cert-manager anyway?" )
if askErr != nil {
return fmt . Errorf ( "asking for confirmation: %w" , err )
}
if ! ok {
2023-05-03 11:11:53 +02:00
cmd . Println ( "Skipping upgrade." )
2023-02-01 11:23:57 +01:00
return nil
}
}
2023-07-11 18:15:29 +02:00
err = u . upgrader . UpgradeHelmServices ( cmd . Context ( ) , conf , idFile , flags . upgradeTimeout , helm . AllowDestructive , flags . force )
2023-02-01 11:23:57 +01:00
}
2023-03-03 09:38:23 +01:00
return err
2022-08-29 16:49:44 +02:00
}
2023-02-01 10:56:47 +01:00
func parseUpgradeApplyFlags ( cmd * cobra . Command ) ( upgradeApplyFlags , error ) {
2023-01-04 13:55:10 +01:00
configPath , err := cmd . Flags ( ) . GetString ( "config" )
if err != nil {
2023-02-01 10:56:47 +01:00
return upgradeApplyFlags { } , err
2023-01-04 13:55:10 +01:00
}
yes , err := cmd . Flags ( ) . GetBool ( "yes" )
if err != nil {
2023-02-01 10:56:47 +01:00
return upgradeApplyFlags { } , err
2023-01-04 13:55:10 +01:00
}
timeout , err := cmd . Flags ( ) . GetDuration ( "timeout" )
if err != nil {
2023-02-01 10:56:47 +01:00
return upgradeApplyFlags { } , err
2023-01-04 13:55:10 +01:00
}
2023-01-31 11:45:31 +01:00
force , err := cmd . Flags ( ) . GetBool ( "force" )
if err != nil {
2023-02-01 10:56:47 +01:00
return upgradeApplyFlags { } , fmt . Errorf ( "parsing force argument: %w" , err )
2023-01-31 11:45:31 +01:00
}
2023-05-22 13:31:20 +02:00
logLevelString , err := cmd . Flags ( ) . GetString ( "tf-log" )
if err != nil {
return upgradeApplyFlags { } , fmt . Errorf ( "parsing tf-log string: %w" , err )
}
logLevel , err := terraform . ParseLogLevel ( logLevelString )
if err != nil {
return upgradeApplyFlags { } , fmt . Errorf ( "parsing Terraform log level %s: %w" , logLevelString , err )
}
return upgradeApplyFlags {
configPath : configPath ,
yes : yes ,
upgradeTimeout : timeout ,
force : force ,
terraformLogLevel : logLevel ,
} , nil
2023-01-04 13:55:10 +01:00
}
2023-02-01 10:56:47 +01:00
type upgradeApplyFlags struct {
2023-05-22 13:31:20 +02:00
configPath string
yes bool
upgradeTimeout time . Duration
force bool
terraformLogLevel terraform . LogLevel
2023-01-04 13:55:10 +01:00
}
2022-08-29 16:49:44 +02:00
type cloudUpgrader interface {
2023-06-21 15:49:42 +02:00
UpgradeNodeVersion ( ctx context . Context , conf * config . Config , force bool ) error
2023-07-11 18:15:29 +02:00
UpgradeHelmServices ( ctx context . Context , config * config . Config , idFile clusterid . File , timeout time . Duration , allowDestructive bool , force bool ) error
2023-05-03 11:11:53 +02:00
UpdateAttestationConfig ( ctx context . Context , newConfig config . AttestationCfg ) error
GetClusterAttestationConfig ( ctx context . Context , variant variant . Variant ) ( config . AttestationCfg , * corev1 . ConfigMap , error )
2023-05-22 13:31:20 +02:00
PlanTerraformMigrations ( ctx context . Context , opts upgrade . TerraformUpgradeOptions ) ( bool , error )
ApplyTerraformMigrations ( ctx context . Context , fileHandler file . Handler , opts upgrade . TerraformUpgradeOptions ) error
CheckTerraformMigrations ( fileHandler file . Handler ) error
CleanUpTerraformMigrations ( fileHandler file . Handler ) error
2023-06-27 13:12:50 +02:00
AddManualStateMigration ( migration terraform . StateMigration )
2022-08-29 16:49:44 +02:00
}
2023-06-22 16:53:40 +02:00
func toPtr [ T any ] ( v T ) * T {
return & v
}