From 576a37b8ffe7be866d08ad7eba25c9882ede9d3f Mon Sep 17 00:00:00 2001 From: Lloyd Parkes Date: Sat, 4 Dec 2021 12:18:53 +1300 Subject: [PATCH 1/6] Added a boolean eventbridge attribute to s3/bucket_notification in order to support the EventBridge notifications for S3 buckets. --- internal/service/s3/bucket_notification.go | 19 ++++++ .../service/s3/bucket_notification_test.go | 66 +++++++++++++++++++ 2 files changed, 85 insertions(+) diff --git a/internal/service/s3/bucket_notification.go b/internal/service/s3/bucket_notification.go index cee91732581..fa12f268109 100644 --- a/internal/service/s3/bucket_notification.go +++ b/internal/service/s3/bucket_notification.go @@ -32,6 +32,12 @@ func ResourceBucketNotification() *schema.Resource { ForceNew: true, }, + "eventbridge": { + Type: schema.TypeBool, + Optional: true, + Default: false, + }, + "topic": { Type: schema.TypeList, Optional: true, @@ -135,6 +141,13 @@ func resourceBucketNotificationPut(d *schema.ResourceData, meta interface{}) err conn := meta.(*conns.AWSClient).S3Conn bucket := d.Get("bucket").(string) + // EventBridge + eventbridgeNotifications := d.Get("eventbridge").(bool) + var eventbridgeConfig *s3.EventBridgeConfiguration + if eventbridgeNotifications { + eventbridgeConfig = &s3.EventBridgeConfiguration{} + } + // TopicNotifications topicNotifications := d.Get("topic").([]interface{}) topicConfigs := make([]*s3.TopicConfiguration, 0, len(topicNotifications)) @@ -295,6 +308,9 @@ func resourceBucketNotificationPut(d *schema.ResourceData, meta interface{}) err } notificationConfiguration := &s3.NotificationConfiguration{} + if eventbridgeConfig != nil { + notificationConfiguration.EventBridgeConfiguration = eventbridgeConfig + } if len(lambdaConfigs) > 0 { notificationConfiguration.LambdaFunctionConfigurations = lambdaConfigs } @@ -380,6 +396,9 @@ func resourceBucketNotificationRead(d *schema.ResourceData, meta interface{}) er d.Set("bucket", d.Id()) + // EventBridge Notification + d.Set("eventbridge", notificationConfigs.EventBridgeConfiguration != nil) + // Topic Notification if err := d.Set("topic", flattenTopicConfigurations(notificationConfigs.TopicConfigurations)); err != nil { return fmt.Errorf("error reading S3 bucket \"%s\" topic notification: %s", d.Id(), err) diff --git a/internal/service/s3/bucket_notification_test.go b/internal/service/s3/bucket_notification_test.go index 6eb2daaa43e..fd4515e2e14 100644 --- a/internal/service/s3/bucket_notification_test.go +++ b/internal/service/s3/bucket_notification_test.go @@ -17,6 +17,30 @@ import ( "github.com/hashicorp/terraform-provider-aws/internal/conns" ) +func TestAccS3BucketNotification_eventbridge(t *testing.T) { + rName := sdkacctest.RandomWithPrefix(acctest.ResourcePrefix) + resourceName := "aws_s3_bucket_notification.notification" + + resource.ParallelTest(t, resource.TestCase{ + PreCheck: func() { acctest.PreCheck(t) }, + ErrorCheck: acctest.ErrorCheck(t, s3.EndpointsID), + Providers: acctest.Providers, + CheckDestroy: testAccCheckBucketNotificationDestroy, + Steps: []resource.TestStep{ + { + Config: testAccBucketNotificationEventBridgeConfig(rName), + Check: resource.ComposeTestCheckFunc( + testAccCheckBucketEventBridgeNotification("aws_s3_bucket.bucket")), + }, + { + ResourceName: resourceName, + ImportState: true, + ImportStateVerify: true, + }, + }, + }) +} + func TestAccS3BucketNotification_lambdaFunction(t *testing.T) { rName := sdkacctest.RandomWithPrefix(acctest.ResourcePrefix) resourceName := "aws_s3_bucket_notification.notification" @@ -361,6 +385,31 @@ func testAccCheckBucketTopicNotification(n, i, t string, events []string, filter } } +func testAccCheckBucketEventBridgeNotification(n string) resource.TestCheckFunc { + return func(s *terraform.State) error { + rs := s.RootModule().Resources[n] + conn := acctest.Provider.Meta().(*conns.AWSClient).S3Conn + + err := resource.Retry(1*time.Minute, func() *resource.RetryError { + out, err := conn.GetBucketNotificationConfiguration(&s3.GetBucketNotificationConfigurationRequest{ + Bucket: aws.String(rs.Primary.ID), + }) + + if err != nil { + return resource.NonRetryableError(fmt.Errorf("GetBucketNotification error: %v", err)) + } + + if out.EventBridgeConfiguration == nil { + return resource.RetryableError(fmt.Errorf("No EventBridge configuration: %#v", out)) + } else { + return nil + } + }) + + return err + } +} + func testAccCheckBucketQueueNotification(n, i, t string, events []string, filters *s3.KeyFilter) resource.TestCheckFunc { return func(s *terraform.State) error { rs := s.RootModule().Resources[n] @@ -475,6 +524,23 @@ func testAccCheckBucketLambdaFunctionConfiguration(n, i, t string, events []stri } } +func testAccBucketNotificationEventBridgeConfig(rName string) string { + return fmt.Sprintf(` +data "aws_partition" "current" {} + +resource "aws_s3_bucket" "bucket" { + bucket = %[1]q + acl = "public-read" +} + +resource "aws_s3_bucket_notification" "notification" { + bucket = aws_s3_bucket.bucket.id + + eventbridge = true +} +`, rName) +} + func testAccBucketNotificationTopicMultipleConfig(rName string) string { return fmt.Sprintf(` data "aws_partition" "current" {} From 577a8193268c6993644c63165628a1209f9687e8 Mon Sep 17 00:00:00 2001 From: Lloyd Parkes Date: Sat, 22 Jan 2022 10:58:17 +1300 Subject: [PATCH 2/6] Updated the documentation for s3_bucket_notification and added a changelog entry. --- .changelog/22045.txt | 3 +++ website/docs/r/s3_bucket_notification.html.markdown | 1 + 2 files changed, 4 insertions(+) create mode 100644 .changelog/22045.txt diff --git a/.changelog/22045.txt b/.changelog/22045.txt new file mode 100644 index 00000000000..ae39b87058c --- /dev/null +++ b/.changelog/22045.txt @@ -0,0 +1,3 @@ +```release-note:enhancement +resource/aws_s3_bucket_notification: Add `eventbridge` attribute +``` diff --git a/website/docs/r/s3_bucket_notification.html.markdown b/website/docs/r/s3_bucket_notification.html.markdown index eec6e65bffe..d6d95a86985 100644 --- a/website/docs/r/s3_bucket_notification.html.markdown +++ b/website/docs/r/s3_bucket_notification.html.markdown @@ -304,6 +304,7 @@ The following arguments are supported: * `topic` - (Optional) The notification configuration to SNS Topic (documented below). * `queue` - (Optional) The notification configuration to SQS Queue (documented below). * `lambda_function` - (Optional, Multiple) Used to configure notifications to a Lambda Function (documented below). +* `eventbridge` - (Optional) Set to true to enable Amazon EventBridge notifications. The `topic` notification configuration supports the following: From 034c00ae128129a2f8b3f9c0f2defae06158aeac Mon Sep 17 00:00:00 2001 From: Dirk Avery Date: Wed, 26 Jan 2022 16:01:01 -0500 Subject: [PATCH 3/6] Modernize documentation --- .../r/s3_bucket_notification.html.markdown | 49 ++++++++++--------- 1 file changed, 26 insertions(+), 23 deletions(-) diff --git a/website/docs/r/s3_bucket_notification.html.markdown b/website/docs/r/s3_bucket_notification.html.markdown index d6d95a86985..093e34b9e91 100644 --- a/website/docs/r/s3_bucket_notification.html.markdown +++ b/website/docs/r/s3_bucket_notification.html.markdown @@ -298,37 +298,40 @@ For Terraform's [JSON syntax](https://www.terraform.io/docs/configuration/syntax ## Argument Reference -The following arguments are supported: +The following arguments are required: -* `bucket` - (Required) The name of the bucket to put notification configuration. -* `topic` - (Optional) The notification configuration to SNS Topic (documented below). -* `queue` - (Optional) The notification configuration to SQS Queue (documented below). -* `lambda_function` - (Optional, Multiple) Used to configure notifications to a Lambda Function (documented below). -* `eventbridge` - (Optional) Set to true to enable Amazon EventBridge notifications. +* `bucket` - (Required) Name of the bucket for notification configuration. -The `topic` notification configuration supports the following: +The following arguments are supported: -* `id` - (Optional) Specifies unique identifier for each of the notification configurations. -* `topic_arn` - (Required) Specifies Amazon SNS topic ARN. -* `events` - (Required) Specifies [event](http://docs.aws.amazon.com/AmazonS3/latest/dev/NotificationHowTo.html#notification-how-to-event-types-and-destinations) for which to send notifications. -* `filter_prefix` - (Optional) Specifies object key name prefix. -* `filter_suffix` - (Optional) Specifies object key name suffix. +* `eventbridge` - (Optional) Whether to enable Amazon EventBridge notifications. +* `lambda_function` - (Optional, Multiple) Used to configure notifications to a Lambda Function. See below. +* `queue` - (Optional) Notification configuration to SQS Queue. See below. +* `topic` - (Optional) Notification configuration to SNS Topic. See below. -The `queue` notification configuration supports the following: +### `topic` -* `id` - (Optional) Specifies unique identifier for each of the notification configurations. -* `queue_arn` - (Required) Specifies Amazon SQS queue ARN. -* `events` - (Required) Specifies [event](http://docs.aws.amazon.com/AmazonS3/latest/dev/NotificationHowTo.html#notification-how-to-event-types-and-destinations) for which to send notifications. -* `filter_prefix` - (Optional) Specifies object key name prefix. -* `filter_suffix` - (Optional) Specifies object key name suffix. +* `events` - (Required) [Event](http://docs.aws.amazon.com/AmazonS3/latest/dev/NotificationHowTo.html#notification-how-to-event-types-and-destinations) for which to send notifications. +* `filter_prefix` - (Optional) Object key name prefix. +* `filter_suffix` - (Optional) Object key name suffix. +* `id` - (Optional) Unique identifier for each of the notification configurations. +* `topic_arn` - (Required) SNS topic ARN. -The `lambda_function` notification configuration supports the following: +### `queue` -* `id` - (Optional) Specifies unique identifier for each of the notification configurations. -* `lambda_function_arn` - (Required) Specifies Amazon Lambda function ARN. * `events` - (Required) Specifies [event](http://docs.aws.amazon.com/AmazonS3/latest/dev/NotificationHowTo.html#notification-how-to-event-types-and-destinations) for which to send notifications. -* `filter_prefix` - (Optional) Specifies object key name prefix. -* `filter_suffix` - (Optional) Specifies object key name suffix. +* `filter_prefix` - (Optional) Object key name prefix. +* `filter_suffix` - (Optional) Object key name suffix. +* `id` - (Optional) Unique identifier for each of the notification configurations. +* `queue_arn` - (Required) SQS queue ARN. + +### `lambda_function` + +* `events` - (Required) [Event](http://docs.aws.amazon.com/AmazonS3/latest/dev/NotificationHowTo.html#notification-how-to-event-types-and-destinations) for which to send notifications. +* `filter_prefix` - (Optional) Object key name prefix. +* `filter_suffix` - (Optional) Object key name suffix. +* `id` - (Optional) Unique identifier for each of the notification configurations. +* `lambda_function_arn` - (Required) Lambda function ARN. ## Attributes Reference From e8b71dadeabe5708e26f1ee6933d07f171974db8 Mon Sep 17 00:00:00 2001 From: Dirk Avery Date: Wed, 26 Jan 2022 16:08:36 -0500 Subject: [PATCH 4/6] Fix bad ErrorChecks --- .../bucket_replication_configuration_test.go | 6 ++--- internal/service/s3/bucket_test.go | 25 +++++++++++-------- 2 files changed, 18 insertions(+), 13 deletions(-) diff --git a/internal/service/s3/bucket_replication_configuration_test.go b/internal/service/s3/bucket_replication_configuration_test.go index 2b5a4dc43f0..7466fcdf8b5 100644 --- a/internal/service/s3/bucket_replication_configuration_test.go +++ b/internal/service/s3/bucket_replication_configuration_test.go @@ -130,7 +130,7 @@ func TestAccS3BucketReplicationConfiguration_multipleDestinationsEmptyFilter(t * acctest.PreCheck(t) acctest.PreCheckMultipleRegion(t, 2) }, - ErrorCheck: testAccErrorCheckSkipS3(t), + ErrorCheck: acctest.ErrorCheck(t, s3.EndpointsID), ProviderFactories: acctest.FactoriesAlternate(&providers), CheckDestroy: acctest.CheckWithProviders(testAccCheckReplicationConfigDestroy, &providers), Steps: []resource.TestStep{ @@ -189,7 +189,7 @@ func TestAccS3BucketReplicationConfiguration_multipleDestinationsNonEmptyFilter( acctest.PreCheck(t) acctest.PreCheckMultipleRegion(t, 2) }, - ErrorCheck: testAccErrorCheckSkipS3(t), + ErrorCheck: acctest.ErrorCheck(t, s3.EndpointsID), ProviderFactories: acctest.FactoriesAlternate(&providers), CheckDestroy: acctest.CheckWithProviders(testAccCheckReplicationConfigDestroy, &providers), Steps: []resource.TestStep{ @@ -240,7 +240,7 @@ func TestAccS3BucketReplicationConfiguration_twoDestination(t *testing.T) { acctest.PreCheck(t) acctest.PreCheckMultipleRegion(t, 2) }, - ErrorCheck: testAccErrorCheckSkipS3(t), + ErrorCheck: acctest.ErrorCheck(t, s3.EndpointsID), ProviderFactories: acctest.FactoriesAlternate(&providers), CheckDestroy: acctest.CheckWithProviders(testAccCheckReplicationConfigDestroy, &providers), Steps: []resource.TestStep{ diff --git a/internal/service/s3/bucket_test.go b/internal/service/s3/bucket_test.go index 1f85091c502..06103e65e38 100644 --- a/internal/service/s3/bucket_test.go +++ b/internal/service/s3/bucket_test.go @@ -31,6 +31,18 @@ import ( "github.com/hashicorp/terraform-provider-aws/internal/tfresource" ) +func init() { + acctest.RegisterServiceErrorCheckFunc(s3.EndpointsID, testAccErrorCheckSkip) +} + +// testAccErrorCheckSkip skips tests that have error messages indicating unsupported features +func testAccErrorCheckSkip(t *testing.T) resource.ErrorCheckFunc { + return acctest.ErrorCheckSkipMessagesContaining(t, + "Number of distinct destination bucket ARNs cannot exceed", + "destination is not allowed", + ) +} + func TestAccS3Bucket_Basic_basic(t *testing.T) { bucketName := sdkacctest.RandomWithPrefix("tf-test-bucket") region := acctest.Region() @@ -1493,7 +1505,7 @@ func TestAccS3Bucket_Replication_multipleDestinationsEmptyFilter(t *testing.T) { acctest.PreCheck(t) acctest.PreCheckMultipleRegion(t, 2) }, - ErrorCheck: testAccErrorCheckSkipS3(t), + ErrorCheck: acctest.ErrorCheck(t, s3.EndpointsID), ProviderFactories: acctest.FactoriesAlternate(&providers), CheckDestroy: acctest.CheckWithProviders(testAccCheckBucketDestroyWithProvider, &providers), Steps: []resource.TestStep{ @@ -1560,7 +1572,7 @@ func TestAccS3Bucket_Replication_multipleDestinationsNonEmptyFilter(t *testing.T acctest.PreCheck(t) acctest.PreCheckMultipleRegion(t, 2) }, - ErrorCheck: testAccErrorCheckSkipS3(t), + ErrorCheck: acctest.ErrorCheck(t, s3.EndpointsID), ProviderFactories: acctest.FactoriesAlternate(&providers), CheckDestroy: acctest.CheckWithProviders(testAccCheckBucketDestroyWithProvider, &providers), Steps: []resource.TestStep{ @@ -1631,7 +1643,7 @@ func TestAccS3Bucket_Replication_twoDestination(t *testing.T) { acctest.PreCheck(t) acctest.PreCheckMultipleRegion(t, 2) }, - ErrorCheck: testAccErrorCheckSkipS3(t), + ErrorCheck: acctest.ErrorCheck(t, s3.EndpointsID), ProviderFactories: acctest.FactoriesAlternate(&providers), CheckDestroy: acctest.CheckWithProviders(testAccCheckBucketDestroyWithProvider, &providers), Steps: []resource.TestStep{ @@ -2797,13 +2809,6 @@ func TestWebsiteEndpoint(t *testing.T) { } } -// testAccErrorCheckSkipS3 skips tests that have error messages indicating unsupported features -func testAccErrorCheckSkipS3(t *testing.T) resource.ErrorCheckFunc { - return acctest.ErrorCheckSkipMessagesContaining(t, - "Number of distinct destination bucket ARNs cannot exceed", - ) -} - func testAccCheckBucketDestroy(s *terraform.State) error { return testAccCheckBucketDestroyWithProvider(s, acctest.Provider) } From c036193b1f793d876e3aae3f5a80c17a999fd3db Mon Sep 17 00:00:00 2001 From: Dirk Avery Date: Wed, 26 Jan 2022 16:12:32 -0500 Subject: [PATCH 5/6] Fix docs --- website/docs/r/s3_bucket_notification.html.markdown | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/website/docs/r/s3_bucket_notification.html.markdown b/website/docs/r/s3_bucket_notification.html.markdown index 093e34b9e91..96c292514b0 100644 --- a/website/docs/r/s3_bucket_notification.html.markdown +++ b/website/docs/r/s3_bucket_notification.html.markdown @@ -302,20 +302,20 @@ The following arguments are required: * `bucket` - (Required) Name of the bucket for notification configuration. -The following arguments are supported: +The following arguments are optional: * `eventbridge` - (Optional) Whether to enable Amazon EventBridge notifications. * `lambda_function` - (Optional, Multiple) Used to configure notifications to a Lambda Function. See below. * `queue` - (Optional) Notification configuration to SQS Queue. See below. * `topic` - (Optional) Notification configuration to SNS Topic. See below. -### `topic` +### `lambda_function` * `events` - (Required) [Event](http://docs.aws.amazon.com/AmazonS3/latest/dev/NotificationHowTo.html#notification-how-to-event-types-and-destinations) for which to send notifications. * `filter_prefix` - (Optional) Object key name prefix. * `filter_suffix` - (Optional) Object key name suffix. * `id` - (Optional) Unique identifier for each of the notification configurations. -* `topic_arn` - (Required) SNS topic ARN. +* `lambda_function_arn` - (Required) Lambda function ARN. ### `queue` @@ -325,13 +325,13 @@ The following arguments are supported: * `id` - (Optional) Unique identifier for each of the notification configurations. * `queue_arn` - (Required) SQS queue ARN. -### `lambda_function` +### `topic` * `events` - (Required) [Event](http://docs.aws.amazon.com/AmazonS3/latest/dev/NotificationHowTo.html#notification-how-to-event-types-and-destinations) for which to send notifications. * `filter_prefix` - (Optional) Object key name prefix. * `filter_suffix` - (Optional) Object key name suffix. * `id` - (Optional) Unique identifier for each of the notification configurations. -* `lambda_function_arn` - (Required) Lambda function ARN. +* `topic_arn` - (Required) SNS topic ARN. ## Attributes Reference From 32556bff11b72379440aaae60b278386c399ce87 Mon Sep 17 00:00:00 2001 From: Dirk Avery Date: Wed, 26 Jan 2022 16:12:41 -0500 Subject: [PATCH 6/6] Update changelog --- .changelog/22045.txt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.changelog/22045.txt b/.changelog/22045.txt index ae39b87058c..5357a18e89b 100644 --- a/.changelog/22045.txt +++ b/.changelog/22045.txt @@ -1,3 +1,3 @@ ```release-note:enhancement -resource/aws_s3_bucket_notification: Add `eventbridge` attribute +resource/aws_s3_bucket_notification: Add `eventbridge` argument ```