/** * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. * SPDX-License-Identifier: Apache-2.0. */ #pragma once #include #include #include #include #include namespace Aws { namespace Neptune { namespace Model { /** */ class ModifyEventSubscriptionRequest : public NeptuneRequest { public: AWS_NEPTUNE_API ModifyEventSubscriptionRequest(); // Service request name is the Operation name which will send this request out, // each operation should has unique request name, so that we can get operation's name from this request. // Note: this is not true for response, multiple operations may have the same response name, // so we can not get operation's name from response. inline virtual const char* GetServiceRequestName() const override { return "ModifyEventSubscription"; } AWS_NEPTUNE_API Aws::String SerializePayload() const override; protected: AWS_NEPTUNE_API void DumpBodyToUrl(Aws::Http::URI& uri ) const override; public: /** *

The name of the event notification subscription.

*/ inline const Aws::String& GetSubscriptionName() const{ return m_subscriptionName; } /** *

The name of the event notification subscription.

*/ inline bool SubscriptionNameHasBeenSet() const { return m_subscriptionNameHasBeenSet; } /** *

The name of the event notification subscription.

*/ inline void SetSubscriptionName(const Aws::String& value) { m_subscriptionNameHasBeenSet = true; m_subscriptionName = value; } /** *

The name of the event notification subscription.

*/ inline void SetSubscriptionName(Aws::String&& value) { m_subscriptionNameHasBeenSet = true; m_subscriptionName = std::move(value); } /** *

The name of the event notification subscription.

*/ inline void SetSubscriptionName(const char* value) { m_subscriptionNameHasBeenSet = true; m_subscriptionName.assign(value); } /** *

The name of the event notification subscription.

*/ inline ModifyEventSubscriptionRequest& WithSubscriptionName(const Aws::String& value) { SetSubscriptionName(value); return *this;} /** *

The name of the event notification subscription.

*/ inline ModifyEventSubscriptionRequest& WithSubscriptionName(Aws::String&& value) { SetSubscriptionName(std::move(value)); return *this;} /** *

The name of the event notification subscription.

*/ inline ModifyEventSubscriptionRequest& WithSubscriptionName(const char* value) { SetSubscriptionName(value); return *this;} /** *

The Amazon Resource Name (ARN) of the SNS topic created for event * notification. The ARN is created by Amazon SNS when you create a topic and * subscribe to it.

*/ inline const Aws::String& GetSnsTopicArn() const{ return m_snsTopicArn; } /** *

The Amazon Resource Name (ARN) of the SNS topic created for event * notification. The ARN is created by Amazon SNS when you create a topic and * subscribe to it.

*/ inline bool SnsTopicArnHasBeenSet() const { return m_snsTopicArnHasBeenSet; } /** *

The Amazon Resource Name (ARN) of the SNS topic created for event * notification. The ARN is created by Amazon SNS when you create a topic and * subscribe to it.

*/ inline void SetSnsTopicArn(const Aws::String& value) { m_snsTopicArnHasBeenSet = true; m_snsTopicArn = value; } /** *

The Amazon Resource Name (ARN) of the SNS topic created for event * notification. The ARN is created by Amazon SNS when you create a topic and * subscribe to it.

*/ inline void SetSnsTopicArn(Aws::String&& value) { m_snsTopicArnHasBeenSet = true; m_snsTopicArn = std::move(value); } /** *

The Amazon Resource Name (ARN) of the SNS topic created for event * notification. The ARN is created by Amazon SNS when you create a topic and * subscribe to it.

*/ inline void SetSnsTopicArn(const char* value) { m_snsTopicArnHasBeenSet = true; m_snsTopicArn.assign(value); } /** *

The Amazon Resource Name (ARN) of the SNS topic created for event * notification. The ARN is created by Amazon SNS when you create a topic and * subscribe to it.

*/ inline ModifyEventSubscriptionRequest& WithSnsTopicArn(const Aws::String& value) { SetSnsTopicArn(value); return *this;} /** *

The Amazon Resource Name (ARN) of the SNS topic created for event * notification. The ARN is created by Amazon SNS when you create a topic and * subscribe to it.

*/ inline ModifyEventSubscriptionRequest& WithSnsTopicArn(Aws::String&& value) { SetSnsTopicArn(std::move(value)); return *this;} /** *

The Amazon Resource Name (ARN) of the SNS topic created for event * notification. The ARN is created by Amazon SNS when you create a topic and * subscribe to it.

*/ inline ModifyEventSubscriptionRequest& WithSnsTopicArn(const char* value) { SetSnsTopicArn(value); return *this;} /** *

The type of source that is generating the events. For example, if you want to * be notified of events generated by a DB instance, you would set this parameter * to db-instance. if this value is not specified, all events are returned.

*

Valid values: db-instance | db-parameter-group | db-security-group | * db-snapshot

*/ inline const Aws::String& GetSourceType() const{ return m_sourceType; } /** *

The type of source that is generating the events. For example, if you want to * be notified of events generated by a DB instance, you would set this parameter * to db-instance. if this value is not specified, all events are returned.

*

Valid values: db-instance | db-parameter-group | db-security-group | * db-snapshot

*/ inline bool SourceTypeHasBeenSet() const { return m_sourceTypeHasBeenSet; } /** *

The type of source that is generating the events. For example, if you want to * be notified of events generated by a DB instance, you would set this parameter * to db-instance. if this value is not specified, all events are returned.

*

Valid values: db-instance | db-parameter-group | db-security-group | * db-snapshot

*/ inline void SetSourceType(const Aws::String& value) { m_sourceTypeHasBeenSet = true; m_sourceType = value; } /** *

The type of source that is generating the events. For example, if you want to * be notified of events generated by a DB instance, you would set this parameter * to db-instance. if this value is not specified, all events are returned.

*

Valid values: db-instance | db-parameter-group | db-security-group | * db-snapshot

*/ inline void SetSourceType(Aws::String&& value) { m_sourceTypeHasBeenSet = true; m_sourceType = std::move(value); } /** *

The type of source that is generating the events. For example, if you want to * be notified of events generated by a DB instance, you would set this parameter * to db-instance. if this value is not specified, all events are returned.

*

Valid values: db-instance | db-parameter-group | db-security-group | * db-snapshot

*/ inline void SetSourceType(const char* value) { m_sourceTypeHasBeenSet = true; m_sourceType.assign(value); } /** *

The type of source that is generating the events. For example, if you want to * be notified of events generated by a DB instance, you would set this parameter * to db-instance. if this value is not specified, all events are returned.

*

Valid values: db-instance | db-parameter-group | db-security-group | * db-snapshot

*/ inline ModifyEventSubscriptionRequest& WithSourceType(const Aws::String& value) { SetSourceType(value); return *this;} /** *

The type of source that is generating the events. For example, if you want to * be notified of events generated by a DB instance, you would set this parameter * to db-instance. if this value is not specified, all events are returned.

*

Valid values: db-instance | db-parameter-group | db-security-group | * db-snapshot

*/ inline ModifyEventSubscriptionRequest& WithSourceType(Aws::String&& value) { SetSourceType(std::move(value)); return *this;} /** *

The type of source that is generating the events. For example, if you want to * be notified of events generated by a DB instance, you would set this parameter * to db-instance. if this value is not specified, all events are returned.

*

Valid values: db-instance | db-parameter-group | db-security-group | * db-snapshot

*/ inline ModifyEventSubscriptionRequest& WithSourceType(const char* value) { SetSourceType(value); return *this;} /** *

A list of event categories for a SourceType that you want to subscribe to. * You can see a list of the categories for a given SourceType by using the * DescribeEventCategories action.

*/ inline const Aws::Vector& GetEventCategories() const{ return m_eventCategories; } /** *

A list of event categories for a SourceType that you want to subscribe to. * You can see a list of the categories for a given SourceType by using the * DescribeEventCategories action.

*/ inline bool EventCategoriesHasBeenSet() const { return m_eventCategoriesHasBeenSet; } /** *

A list of event categories for a SourceType that you want to subscribe to. * You can see a list of the categories for a given SourceType by using the * DescribeEventCategories action.

*/ inline void SetEventCategories(const Aws::Vector& value) { m_eventCategoriesHasBeenSet = true; m_eventCategories = value; } /** *

A list of event categories for a SourceType that you want to subscribe to. * You can see a list of the categories for a given SourceType by using the * DescribeEventCategories action.

*/ inline void SetEventCategories(Aws::Vector&& value) { m_eventCategoriesHasBeenSet = true; m_eventCategories = std::move(value); } /** *

A list of event categories for a SourceType that you want to subscribe to. * You can see a list of the categories for a given SourceType by using the * DescribeEventCategories action.

*/ inline ModifyEventSubscriptionRequest& WithEventCategories(const Aws::Vector& value) { SetEventCategories(value); return *this;} /** *

A list of event categories for a SourceType that you want to subscribe to. * You can see a list of the categories for a given SourceType by using the * DescribeEventCategories action.

*/ inline ModifyEventSubscriptionRequest& WithEventCategories(Aws::Vector&& value) { SetEventCategories(std::move(value)); return *this;} /** *

A list of event categories for a SourceType that you want to subscribe to. * You can see a list of the categories for a given SourceType by using the * DescribeEventCategories action.

*/ inline ModifyEventSubscriptionRequest& AddEventCategories(const Aws::String& value) { m_eventCategoriesHasBeenSet = true; m_eventCategories.push_back(value); return *this; } /** *

A list of event categories for a SourceType that you want to subscribe to. * You can see a list of the categories for a given SourceType by using the * DescribeEventCategories action.

*/ inline ModifyEventSubscriptionRequest& AddEventCategories(Aws::String&& value) { m_eventCategoriesHasBeenSet = true; m_eventCategories.push_back(std::move(value)); return *this; } /** *

A list of event categories for a SourceType that you want to subscribe to. * You can see a list of the categories for a given SourceType by using the * DescribeEventCategories action.

*/ inline ModifyEventSubscriptionRequest& AddEventCategories(const char* value) { m_eventCategoriesHasBeenSet = true; m_eventCategories.push_back(value); return *this; } /** *

A Boolean value; set to true to activate the subscription.

*/ inline bool GetEnabled() const{ return m_enabled; } /** *

A Boolean value; set to true to activate the subscription.

*/ inline bool EnabledHasBeenSet() const { return m_enabledHasBeenSet; } /** *

A Boolean value; set to true to activate the subscription.

*/ inline void SetEnabled(bool value) { m_enabledHasBeenSet = true; m_enabled = value; } /** *

A Boolean value; set to true to activate the subscription.

*/ inline ModifyEventSubscriptionRequest& WithEnabled(bool value) { SetEnabled(value); return *this;} private: Aws::String m_subscriptionName; bool m_subscriptionNameHasBeenSet = false; Aws::String m_snsTopicArn; bool m_snsTopicArnHasBeenSet = false; Aws::String m_sourceType; bool m_sourceTypeHasBeenSet = false; Aws::Vector m_eventCategories; bool m_eventCategoriesHasBeenSet = false; bool m_enabled; bool m_enabledHasBeenSet = false; }; } // namespace Model } // namespace Neptune } // namespace Aws