Skip to content

Commit

Permalink
aws: fix issue with creating bucket in us-east-1
Browse files Browse the repository at this point in the history
Region us-east-1 isn't a valid parameter to a createBucket request.
This caused the following error when uploading:

Error:
    uploading variants:
    uploading image:
    ensuring bucket exists:
    creating bucket xxx:
    operation error S3:
    CreateBucket, https response error StatusCode: 400, RequestID: xxx, HostID: xx,
    api error InvalidLocationConstraint:
    The specified location-constraint is not valid

Signed-off-by: Paul Meyer <[email protected]>
  • Loading branch information
katexochen committed Oct 13, 2023
1 parent 8de7dd1 commit 490cde8
Show file tree
Hide file tree
Showing 4 changed files with 67 additions and 15 deletions.
7 changes: 7 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -177,6 +177,13 @@ The description of the AMI.

The bucket to upload the image to during the upload process.

### `base.aws.bucketRegionConstraint` / `variant.<name>.aws.bucketRegionConstraint`

- Default: none (defaults to `us-east-1`)
- Required: no
- Template: no

The region where the buckets exist or should be created.

### `base.aws.blobName` / `variant.<name>.aws.blobName`

Expand Down
22 changes: 15 additions & 7 deletions aws/uploader.go
Original file line number Diff line number Diff line change
Expand Up @@ -163,12 +163,17 @@ func (u *Uploader) ensureBucket(ctx context.Context) error {
return nil
}
u.log.Printf("Bucket %s doesn't exist. Creating.", bucket)
_, err = s3C.CreateBucket(ctx, &s3.CreateBucketInput{
Bucket: &bucket,
CreateBucketConfiguration: &s3types.CreateBucketConfiguration{
LocationConstraint: s3types.BucketLocationConstraint(u.config.AWS.Region),
},
})
var createBucketConfig *s3types.CreateBucketConfiguration
if u.config.AWS.BucketLocationConstraint != "" {
createBucketConfig = &s3types.CreateBucketConfiguration{
LocationConstraint: s3types.BucketLocationConstraint(u.config.AWS.BucketLocationConstraint),
}
}
req := &s3.CreateBucketInput{
Bucket: &bucket,
CreateBucketConfiguration: createBucketConfig,
}
_, err = s3C.CreateBucket(ctx, req)
if err != nil {
return fmt.Errorf("creating bucket %s: %w", bucket, err)
}
Expand Down Expand Up @@ -253,6 +258,7 @@ func (u *Uploader) importSnapshot(ctx context.Context) (string, error) {
},
})
if err != nil {
log.Println(bucketPermissionHelpText)
return "", fmt.Errorf("importing snapshot: %w", err)
}
if importResp.ImportTaskId == nil {
Expand Down Expand Up @@ -550,6 +556,8 @@ func (u *Uploader) sts(ctx context.Context) (stsAPI, error) {
return sts.NewFromConfig(cfg), nil
}

const bucketPermissionHelpText = "Importing snapshot failed with \"deleted\" status. This may indicate a missing service role for the AWS service \"vmie.amazonaws.com\" to access the snapshot. See https://docs.aws.amazon.com/vm-import/latest/userguide/required-permissions.html#vmimport-role for details."

func waitForSnapshotImport(ctx context.Context, ec2C ec2API, importTaskID string) (string, error) {
start := time.Now()
for {
Expand Down Expand Up @@ -586,7 +594,7 @@ func waitForSnapshotImport(ctx context.Context, ec2C ec2API, importTaskID string
case string(ec2types.SnapshotStateError):
return "", fmt.Errorf("importing snapshot: task failed with message %q", statusMessage)
case string("deleted"):
log.Printf("Importing snapshot failed with \"deleted\" status. This may indicate a missing service role for the AWS service \"vmie.amazonaws.com\" to access the snapshot. See https://docs.aws.amazon.com/vm-import/latest/userguide/required-permissions.html#vmimport-role for details.")
log.Printf(bucketPermissionHelpText)
return "", fmt.Errorf("importing snapshot: import state deleted with message %q", statusMessage)
default:
return "", fmt.Errorf("importing snapshot: status %s with message %q",
Expand Down
17 changes: 9 additions & 8 deletions config/config.go
Original file line number Diff line number Diff line change
Expand Up @@ -163,14 +163,15 @@ type fieldTemplateData struct {
}

type AWSConfig struct {
Region string `toml:"region,omitempty"`
ReplicationRegions []string `toml:"replicationRegions,omitempty"`
AMIName string `toml:"amiName,omitempty" template:"true"`
AMIDescription string `toml:"amiDescription,omitempty" template:"true"`
Bucket string `toml:"bucket,omitempty" template:"true"`
BlobName string `toml:"blobName,omitempty" template:"true"`
SnapshotName string `toml:"snapshotName,omitempty" template:"true"`
Publish Option[bool] `toml:"publish,omitempty"`
Region string `toml:"region,omitempty"`
ReplicationRegions []string `toml:"replicationRegions,omitempty"`
AMIName string `toml:"amiName,omitempty" template:"true"`
AMIDescription string `toml:"amiDescription,omitempty" template:"true"`
Bucket string `toml:"bucket,omitempty" template:"true"`
BucketLocationConstraint string `toml:"bucketLocationConstraint,omitempty" template:"false"`
BlobName string `toml:"blobName,omitempty" template:"true"`
SnapshotName string `toml:"snapshotName,omitempty" template:"true"`
Publish Option[bool] `toml:"publish,omitempty"`
}

type AzureConfig struct {
Expand Down
36 changes: 36 additions & 0 deletions config/validation.rego
Original file line number Diff line number Diff line change
Expand Up @@ -110,6 +110,42 @@ deny[msg] {
msg = sprintf("bucket name %q must not end with the suffix --ol-s3", [input.AWS.Bucket])
}

deny[msg] {
input.Provider == "aws"
input.AWS.BucketLocationConstraint in [
"af-south-1",
"ap-east-1",
"ap-northeast-1",
"ap-northeast-2",
"ap-northeast-3",
"ap-south-1",
"ap-southeast-1",
"ap-southeast-2",
"ap-southeast-3",
"ca-central-1",
"cn-north-1",
"cn-northwest-1",
"EU",
"eu-central-1",
"eu-north-1",
"eu-south-1",
"eu-west-1",
"eu-west-2",
"eu-west-3",
"me-south-1",
"sa-east-1",
"us-east-2",
"us-gov-east-1",
"us-gov-west-1",
"us-west-1",
"us-west-2",
"ap-south-2",
"eu-south-2",
]

msg = sprintf("%q is not a valid bucket location constraint", [ input.AWS.BucketLocationConstraint ] )
}

deny[msg] {
input.Provider == "aws"
not is_boolean(input.AWS.Publish)
Expand Down

0 comments on commit 490cde8

Please sign in to comment.