mirror of
https://github.com/edgelesssys/constellation.git
synced 2025-01-25 14:56:18 -05:00
cli: allow any well formatted zone in iam create
This commit is contained in:
parent
653bf3621d
commit
6694eabebd
@ -402,18 +402,9 @@ func (c *awsIAMCreator) parseFlagsAndSetupConfig(cmd *cobra.Command, flags iamFl
|
|||||||
zone: zone,
|
zone: zone,
|
||||||
}
|
}
|
||||||
|
|
||||||
if strings.HasPrefix(zone, "eu-central-1") {
|
flags.aws.region, err = awsZoneToRegion(zone)
|
||||||
flags.aws.region = "eu-central-1"
|
if err != nil {
|
||||||
} else if strings.HasPrefix(zone, "eu-west-1") {
|
return iamFlags{}, fmt.Errorf("invalid AWS zone. To find a valid zone, please refer to our docs and https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/using-regions-availability-zones.html#concepts-availability-zones")
|
||||||
flags.aws.region = "eu-west-1"
|
|
||||||
} else if strings.HasPrefix(zone, "eu-west-3") {
|
|
||||||
flags.aws.region = "eu-west-3"
|
|
||||||
} else if strings.HasPrefix(zone, "us-east-2") {
|
|
||||||
flags.aws.region = "us-east-2"
|
|
||||||
} else if strings.HasPrefix(zone, "ap-south-1") {
|
|
||||||
flags.aws.region = "ap-south-1"
|
|
||||||
} else {
|
|
||||||
return iamFlags{}, fmt.Errorf("invalid AWS region, to find a correct region please refer to our docs and https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/using-regions-availability-zones.html#concepts-availability-zones")
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Setup IAM config.
|
// Setup IAM config.
|
||||||
@ -610,3 +601,17 @@ func parseIDFile(serviceAccountKeyBase64 string) (map[string]string, error) {
|
|||||||
}
|
}
|
||||||
return out, nil
|
return out, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// awsZoneToRegion converts an AWS zone string to a region string.
|
||||||
|
// Example: "us-east-1a" -> "us-east-1"
|
||||||
|
// It does not check against a list of valid zones.
|
||||||
|
// Instead, it just checks that the zone string is in the correct format:
|
||||||
|
// "The code for Availability Zone is its Region code followed by a letter identifier."
|
||||||
|
// https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/using-regions-availability-zones.html#concepts-availability-zones .
|
||||||
|
func awsZoneToRegion(zone string) (string, error) {
|
||||||
|
parts := strings.Split(zone, "-")
|
||||||
|
if len(parts) < 3 || len(parts[2]) < 1 {
|
||||||
|
return "", fmt.Errorf("invalid zone string: %s", zone)
|
||||||
|
}
|
||||||
|
return fmt.Sprintf("%s-%s-%c", parts[0], parts[1], parts[2][0]), nil
|
||||||
|
}
|
||||||
|
@ -212,7 +212,7 @@ func TestIAMCreateAWS(t *testing.T) {
|
|||||||
setupFs: defaultFs,
|
setupFs: defaultFs,
|
||||||
creator: &stubIAMCreator{id: validIAMIDFile},
|
creator: &stubIAMCreator{id: validIAMIDFile},
|
||||||
provider: cloudprovider.AWS,
|
provider: cloudprovider.AWS,
|
||||||
zoneFlag: "us-west-5b",
|
zoneFlag: "us-west",
|
||||||
prefixFlag: "test",
|
prefixFlag: "test",
|
||||||
yesFlag: true,
|
yesFlag: true,
|
||||||
wantErr: true,
|
wantErr: true,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user