Skip to content

Commit

Permalink
Add custom vpc support in AWS cloud prepare
Browse files Browse the repository at this point in the history
Signed-off-by: Aswin Suryanarayanan <[email protected]>
  • Loading branch information
aswinsuryan committed Sep 21, 2024
1 parent bf332e0 commit e0ea660
Show file tree
Hide file tree
Showing 4 changed files with 40 additions and 13 deletions.
7 changes: 7 additions & 0 deletions cmd/subctl/aws.go
Original file line number Diff line number Diff line change
Expand Up @@ -73,6 +73,13 @@ 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")
}

addGeneralAWSFlags(awsPrepareCmd)
Expand Down
2 changes: 1 addition & 1 deletion go.mod
Original file line number Diff line number Diff line change
Expand Up @@ -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.20240921031613-ed4e9907bbfc
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
Expand Down
4 changes: 2 additions & 2 deletions go.sum
Original file line number Diff line number Diff line change
Expand Up @@ -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.20240921031613-ed4e9907bbfc h1:v2Ffmfo3KJNXDJAkcyx4Eqg2Sp5z0DMizfXPO2JBLAQ=
github.com/submariner-io/cloud-prepare v0.19.0-m3.0.20240921031613-ed4e9907bbfc/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=
Expand Down
40 changes: 30 additions & 10 deletions pkg/cloud/aws/aws.go
Original file line number Diff line number Diff line change
Expand Up @@ -30,13 +30,16 @@ 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
}

// RunOn runs the given function on AWS, supplying it with a cloud instance connected to AWS and a reporter that writes to CLI.
Expand All @@ -57,11 +60,28 @@ 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)
if err != nil {
return status.Error(err, "error loading default config")
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))
}

awsCloud, err := aws.NewCloudFromSettings(
config.CredentialsFile,
config.Profile,
config.InfraID,
config.Region,
cloudOptions...,
)

status.End()

restMapper, err := util.BuildRestMapper(clusterInfo.RestConfig)
Expand Down

0 comments on commit e0ea660

Please sign in to comment.