|
|
|
|
@ -293,6 +293,13 @@ func resourceAwsS3Bucket() *schema.Resource {
|
|
|
|
|
Optional: true,
|
|
|
|
|
Default: false,
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
"acceleration_status": &schema.Schema{
|
|
|
|
|
Type: schema.TypeString,
|
|
|
|
|
Optional: true,
|
|
|
|
|
Computed: true,
|
|
|
|
|
ValidateFunc: validateS3BucketAccelerationStatus,
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
@ -395,6 +402,12 @@ func resourceAwsS3BucketUpdate(d *schema.ResourceData, meta interface{}) error {
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if d.HasChange("acceleration_status") {
|
|
|
|
|
if err := resourceAwsS3BucketAccelerationUpdate(s3conn, d); err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return resourceAwsS3BucketRead(d, meta)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@ -525,6 +538,16 @@ func resourceAwsS3BucketRead(d *schema.ResourceData, meta interface{}) error {
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//read the acceleration status
|
|
|
|
|
accelerate, err := s3conn.GetBucketAccelerateConfiguration(&s3.GetBucketAccelerateConfigurationInput{
|
|
|
|
|
Bucket: aws.String(d.Id()),
|
|
|
|
|
})
|
|
|
|
|
log.Printf("[DEBUG] S3 bucket: %s, read Acceleration: %v", d.Id(), accelerate)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
d.Set("acceleration_status", accelerate.Status)
|
|
|
|
|
|
|
|
|
|
// Read the logging configuration
|
|
|
|
|
logging, err := s3conn.GetBucketLogging(&s3.GetBucketLoggingInput{
|
|
|
|
|
Bucket: aws.String(d.Id()),
|
|
|
|
|
@ -1095,6 +1118,26 @@ func resourceAwsS3BucketLoggingUpdate(s3conn *s3.S3, d *schema.ResourceData) err
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func resourceAwsS3BucketAccelerationUpdate(s3conn *s3.S3, d *schema.ResourceData) error {
|
|
|
|
|
bucket := d.Get("bucket").(string)
|
|
|
|
|
enableAcceleration := d.Get("acceleration_status").(string)
|
|
|
|
|
|
|
|
|
|
i := &s3.PutBucketAccelerateConfigurationInput{
|
|
|
|
|
Bucket: aws.String(bucket),
|
|
|
|
|
AccelerateConfiguration: &s3.AccelerateConfiguration{
|
|
|
|
|
Status: aws.String(enableAcceleration),
|
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
log.Printf("[DEBUG] S3 put bucket acceleration: %#v", i)
|
|
|
|
|
|
|
|
|
|
_, err := s3conn.PutBucketAccelerateConfiguration(i)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return fmt.Errorf("Error putting S3 acceleration: %s", err)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func resourceAwsS3BucketLifecycleUpdate(s3conn *s3.S3, d *schema.ResourceData) error {
|
|
|
|
|
bucket := d.Get("bucket").(string)
|
|
|
|
|
|
|
|
|
|
@ -1290,6 +1333,18 @@ func normalizeRegion(region string) string {
|
|
|
|
|
return region
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func validateS3BucketAccelerationStatus(v interface{}, k string) (ws []string, errors []error) {
|
|
|
|
|
validTypes := map[string]struct{}{
|
|
|
|
|
"Enabled": struct{}{},
|
|
|
|
|
"Suspended": struct{}{},
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if _, ok := validTypes[v.(string)]; !ok {
|
|
|
|
|
errors = append(errors, fmt.Errorf("S3 Bucket Acceleration Status %q is invalid, must be %q or %q", v.(string), "Enabled", "Suspended"))
|
|
|
|
|
}
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func expirationHash(v interface{}) int {
|
|
|
|
|
var buf bytes.Buffer
|
|
|
|
|
m := v.(map[string]interface{})
|
|
|
|
|
|