/**
* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
* SPDX-License-Identifier: Apache-2.0.
*/
#pragma once
#include Specifies the configuration for publishing messages to an Amazon Simple Queue
* Service (Amazon SQS) queue when Amazon S3 detects specified
* events.See Also:
AWS
* API Reference
The Amazon Resource Name (ARN) of the Amazon SQS queue to which Amazon S3 * publishes a message when it detects events of the specified type.
*/ inline const Aws::String& GetQueueArn() const{ return m_queueArn; } /** *The Amazon Resource Name (ARN) of the Amazon SQS queue to which Amazon S3 * publishes a message when it detects events of the specified type.
*/ inline bool QueueArnHasBeenSet() const { return m_queueArnHasBeenSet; } /** *The Amazon Resource Name (ARN) of the Amazon SQS queue to which Amazon S3 * publishes a message when it detects events of the specified type.
*/ inline void SetQueueArn(const Aws::String& value) { m_queueArnHasBeenSet = true; m_queueArn = value; } /** *The Amazon Resource Name (ARN) of the Amazon SQS queue to which Amazon S3 * publishes a message when it detects events of the specified type.
*/ inline void SetQueueArn(Aws::String&& value) { m_queueArnHasBeenSet = true; m_queueArn = std::move(value); } /** *The Amazon Resource Name (ARN) of the Amazon SQS queue to which Amazon S3 * publishes a message when it detects events of the specified type.
*/ inline void SetQueueArn(const char* value) { m_queueArnHasBeenSet = true; m_queueArn.assign(value); } /** *The Amazon Resource Name (ARN) of the Amazon SQS queue to which Amazon S3 * publishes a message when it detects events of the specified type.
*/ inline QueueConfiguration& WithQueueArn(const Aws::String& value) { SetQueueArn(value); return *this;} /** *The Amazon Resource Name (ARN) of the Amazon SQS queue to which Amazon S3 * publishes a message when it detects events of the specified type.
*/ inline QueueConfiguration& WithQueueArn(Aws::String&& value) { SetQueueArn(std::move(value)); return *this;} /** *The Amazon Resource Name (ARN) of the Amazon SQS queue to which Amazon S3 * publishes a message when it detects events of the specified type.
*/ inline QueueConfiguration& WithQueueArn(const char* value) { SetQueueArn(value); return *this;} /** *A collection of bucket events for which to send notifications
*/ inline const Aws::VectorA collection of bucket events for which to send notifications
*/ inline bool EventsHasBeenSet() const { return m_eventsHasBeenSet; } /** *A collection of bucket events for which to send notifications
*/ inline void SetEvents(const Aws::VectorA collection of bucket events for which to send notifications
*/ inline void SetEvents(Aws::VectorA collection of bucket events for which to send notifications
*/ inline QueueConfiguration& WithEvents(const Aws::VectorA collection of bucket events for which to send notifications
*/ inline QueueConfiguration& WithEvents(Aws::VectorA collection of bucket events for which to send notifications
*/ inline QueueConfiguration& AddEvents(const Event& value) { m_eventsHasBeenSet = true; m_events.push_back(value); return *this; } /** *A collection of bucket events for which to send notifications
*/ inline QueueConfiguration& AddEvents(Event&& value) { m_eventsHasBeenSet = true; m_events.push_back(std::move(value)); return *this; } inline const NotificationConfigurationFilter& GetFilter() const{ return m_filter; } inline bool FilterHasBeenSet() const { return m_filterHasBeenSet; } inline void SetFilter(const NotificationConfigurationFilter& value) { m_filterHasBeenSet = true; m_filter = value; } inline void SetFilter(NotificationConfigurationFilter&& value) { m_filterHasBeenSet = true; m_filter = std::move(value); } inline QueueConfiguration& WithFilter(const NotificationConfigurationFilter& value) { SetFilter(value); return *this;} inline QueueConfiguration& WithFilter(NotificationConfigurationFilter&& value) { SetFilter(std::move(value)); return *this;} private: Aws::String m_id; bool m_idHasBeenSet; Aws::String m_queueArn; bool m_queueArnHasBeenSet; Aws::Vector