From 66a1bbafe9fc4eb2c201c1edc0ec407b74eb2bc0 Mon Sep 17 00:00:00 2001 From: Aswin Suryanarayanan Date: Fri, 20 Sep 2024 23:21:52 -0400 Subject: [PATCH] Add custom vpc support in AWS cloud prepare Signed-off-by: Aswin Suryanarayanan --- cmd/subctl/aws.go | 9 +++++++++ go.mod | 2 +- go.sum | 4 ++-- pkg/cloud/aws/aws.go | 46 +++++++++++++++++++++++++++++++++++--------- 4 files changed, 49 insertions(+), 12 deletions(-) diff --git a/cmd/subctl/aws.go b/cmd/subctl/aws.go index 8db2d8282..6828f9151 100644 --- a/cmd/subctl/aws.go +++ b/cmd/subctl/aws.go @@ -73,6 +73,15 @@ func init() { "OCP metadata.json file (or directory containing it) to read AWS infra ID and region from (Takes precedence over the flags)") command.Flags().StringVar(&awsConfig.Profile, "profile", cpaws.DefaultProfile(), "AWS profile to use for credentials") command.Flags().StringVar(&awsConfig.CredentialsFile, "credentials", cpaws.DefaultCredentialsFile(), "AWS credentials configuration file") + + command.Flags().StringVar(&awsConfig.ControlPlaneSecurityGroup, "control-plane-security-group", "", + "Custom AWS control plane security group name if the default is not used while provisioning") + command.Flags().StringVar(&awsConfig.WorkerSecurityGroup, "worker-security-group", "", + "Custom AWS worker security group name if the default is not used while provisioning") + command.Flags().StringVar(&awsConfig.VpcName, "vpc-name", "", + "Custom AWS VPC name if the default is not used while provisioning") + command.Flags().StringSliceVar(&awsConfig.SubnetNames, "subnet-names", nil, + "Custom AWS subnet names if the default is not used while provisioning (comma-separated list)") } addGeneralAWSFlags(awsPrepareCmd) diff --git a/go.mod b/go.mod index 70d921be4..2d7f1c58f 100644 --- a/go.mod +++ b/go.mod @@ -17,7 +17,7 @@ require ( github.com/spf13/cobra v1.8.1 github.com/spf13/pflag v1.0.5 github.com/submariner-io/admiral v0.19.0-m3 - github.com/submariner-io/cloud-prepare v0.19.0-m3 + github.com/submariner-io/cloud-prepare v0.19.0-m3.0.20240925181844-e1aa569fa944 github.com/submariner-io/lighthouse v0.19.0-m3 github.com/submariner-io/shipyard v0.19.0-m3 github.com/submariner-io/submariner v0.19.0-m3.0.20240917155703-5a6c358065a2 diff --git a/go.sum b/go.sum index 22f5352aa..16fa0519a 100644 --- a/go.sum +++ b/go.sum @@ -516,8 +516,8 @@ github.com/stretchr/testify v1.9.0 h1:HtqpIVDClZ4nwg75+f6Lvsy/wHu+3BoSGCbBAcpTsT github.com/stretchr/testify v1.9.0/go.mod h1:r2ic/lqez/lEtzL7wO/rwa5dbSLXVDPFyf8C91i36aY= github.com/submariner-io/admiral v0.19.0-m3 h1:LTkYxCvB8S1210P2FZtCb6dzjaPpIgBrRQxZkH/snDo= github.com/submariner-io/admiral v0.19.0-m3/go.mod h1:xRpP1rDOblEdPHr0qrC+plcTNfShYJAOH2fexqOmI1A= -github.com/submariner-io/cloud-prepare v0.19.0-m3 h1:f2PR4fFSJnwI5Ta9gTSmH0+Y2ZgES+hmBvAF29j45vM= -github.com/submariner-io/cloud-prepare v0.19.0-m3/go.mod h1:LEyZLtFxBytG73MPS2kvmF/ASoNmVPIKrEjroWJFSOQ= +github.com/submariner-io/cloud-prepare v0.19.0-m3.0.20240925181844-e1aa569fa944 h1:pLaPa91BDaNayahsU22G0FJyTUm2vogSEbnDiusg8CA= +github.com/submariner-io/cloud-prepare v0.19.0-m3.0.20240925181844-e1aa569fa944/go.mod h1:LEyZLtFxBytG73MPS2kvmF/ASoNmVPIKrEjroWJFSOQ= github.com/submariner-io/lighthouse v0.19.0-m3 h1:CDv7V6lM/ixurJKvM9H9D2ckVXD9bJpY4F2IHPHcp/8= github.com/submariner-io/lighthouse v0.19.0-m3/go.mod h1:SA5PyBm+pM2Dx2MgWFNz/eJPN3Wde4BrnNWysWQzBRQ= github.com/submariner-io/shipyard v0.19.0-m3 h1:NliwAktRPF4OsLj1TDgpaOJD/bmmZW/FH9+mJmWgxbk= diff --git a/pkg/cloud/aws/aws.go b/pkg/cloud/aws/aws.go index 269824a76..3d5b02c1a 100644 --- a/pkg/cloud/aws/aws.go +++ b/pkg/cloud/aws/aws.go @@ -30,13 +30,17 @@ import ( ) type Config struct { - Gateways int - InfraID string - Region string - Profile string - CredentialsFile string - OcpMetadataFile string - GWInstanceType string + Gateways int + InfraID string + Region string + Profile string + CredentialsFile string + OcpMetadataFile string + GWInstanceType string + ControlPlaneSecurityGroup string + WorkerSecurityGroup string + VpcName string + SubnetNames []string } // RunOn runs the given function on AWS, supplying it with a cloud instance connected to AWS and a reporter that writes to CLI. @@ -57,9 +61,33 @@ func RunOn(clusterInfo *cluster.Info, config *Config, status reporter.Interface, status.Start("Initializing AWS connectivity") - awsCloud, err := aws.NewCloudFromSettings(config.CredentialsFile, config.Profile, config.InfraID, config.Region) + var cloudOptions []aws.CloudOption + + if config.ControlPlaneSecurityGroup != "" { + cloudOptions = append(cloudOptions, aws.WithControlPlaneSecurityGroup(config.ControlPlaneSecurityGroup)) + } + + if config.WorkerSecurityGroup != "" { + cloudOptions = append(cloudOptions, aws.WithWorkerSecurityGroup(config.WorkerSecurityGroup)) + } + + if config.VpcName != "" { + cloudOptions = append(cloudOptions, aws.WithVPCName(config.VpcName)) + } + + if len(config.SubnetNames) > 0 { + cloudOptions = append(cloudOptions, aws.WithPublicSubnetList(config.SubnetNames)) + } + + awsCloud, err := aws.NewCloudFromSettings( + config.CredentialsFile, + config.Profile, + config.InfraID, + config.Region, + cloudOptions..., + ) if err != nil { - return status.Error(err, "error loading default config") + return status.Error(err, "error creating cloud object from settings") } status.End()