/** * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. * SPDX-License-Identifier: Apache-2.0. */ #pragma once #include #include #include #include #include #include #include namespace Aws { namespace WAF { namespace Model { /** */ class CreateRateBasedRuleRequest : public WAFRequest { public: AWS_WAF_API CreateRateBasedRuleRequest(); // 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 "CreateRateBasedRule"; } AWS_WAF_API Aws::String SerializePayload() const override; AWS_WAF_API Aws::Http::HeaderValueCollection GetRequestSpecificHeaders() const override; /** *

A friendly name or description of the RateBasedRule. You can't change * the name of a RateBasedRule after you create it.

*/ inline const Aws::String& GetName() const{ return m_name; } /** *

A friendly name or description of the RateBasedRule. You can't change * the name of a RateBasedRule after you create it.

*/ inline bool NameHasBeenSet() const { return m_nameHasBeenSet; } /** *

A friendly name or description of the RateBasedRule. You can't change * the name of a RateBasedRule after you create it.

*/ inline void SetName(const Aws::String& value) { m_nameHasBeenSet = true; m_name = value; } /** *

A friendly name or description of the RateBasedRule. You can't change * the name of a RateBasedRule after you create it.

*/ inline void SetName(Aws::String&& value) { m_nameHasBeenSet = true; m_name = std::move(value); } /** *

A friendly name or description of the RateBasedRule. You can't change * the name of a RateBasedRule after you create it.

*/ inline void SetName(const char* value) { m_nameHasBeenSet = true; m_name.assign(value); } /** *

A friendly name or description of the RateBasedRule. You can't change * the name of a RateBasedRule after you create it.

*/ inline CreateRateBasedRuleRequest& WithName(const Aws::String& value) { SetName(value); return *this;} /** *

A friendly name or description of the RateBasedRule. You can't change * the name of a RateBasedRule after you create it.

*/ inline CreateRateBasedRuleRequest& WithName(Aws::String&& value) { SetName(std::move(value)); return *this;} /** *

A friendly name or description of the RateBasedRule. You can't change * the name of a RateBasedRule after you create it.

*/ inline CreateRateBasedRuleRequest& WithName(const char* value) { SetName(value); return *this;} /** *

A friendly name or description for the metrics for this * RateBasedRule. The name can contain only alphanumeric characters * (A-Z, a-z, 0-9), with maximum length 128 and minimum length one. It can't * contain whitespace or metric names reserved for AWS WAF, including "All" and * "Default_Action." You can't change the name of the metric after you create the * RateBasedRule.

*/ inline const Aws::String& GetMetricName() const{ return m_metricName; } /** *

A friendly name or description for the metrics for this * RateBasedRule. The name can contain only alphanumeric characters * (A-Z, a-z, 0-9), with maximum length 128 and minimum length one. It can't * contain whitespace or metric names reserved for AWS WAF, including "All" and * "Default_Action." You can't change the name of the metric after you create the * RateBasedRule.

*/ inline bool MetricNameHasBeenSet() const { return m_metricNameHasBeenSet; } /** *

A friendly name or description for the metrics for this * RateBasedRule. The name can contain only alphanumeric characters * (A-Z, a-z, 0-9), with maximum length 128 and minimum length one. It can't * contain whitespace or metric names reserved for AWS WAF, including "All" and * "Default_Action." You can't change the name of the metric after you create the * RateBasedRule.

*/ inline void SetMetricName(const Aws::String& value) { m_metricNameHasBeenSet = true; m_metricName = value; } /** *

A friendly name or description for the metrics for this * RateBasedRule. The name can contain only alphanumeric characters * (A-Z, a-z, 0-9), with maximum length 128 and minimum length one. It can't * contain whitespace or metric names reserved for AWS WAF, including "All" and * "Default_Action." You can't change the name of the metric after you create the * RateBasedRule.

*/ inline void SetMetricName(Aws::String&& value) { m_metricNameHasBeenSet = true; m_metricName = std::move(value); } /** *

A friendly name or description for the metrics for this * RateBasedRule. The name can contain only alphanumeric characters * (A-Z, a-z, 0-9), with maximum length 128 and minimum length one. It can't * contain whitespace or metric names reserved for AWS WAF, including "All" and * "Default_Action." You can't change the name of the metric after you create the * RateBasedRule.

*/ inline void SetMetricName(const char* value) { m_metricNameHasBeenSet = true; m_metricName.assign(value); } /** *

A friendly name or description for the metrics for this * RateBasedRule. The name can contain only alphanumeric characters * (A-Z, a-z, 0-9), with maximum length 128 and minimum length one. It can't * contain whitespace or metric names reserved for AWS WAF, including "All" and * "Default_Action." You can't change the name of the metric after you create the * RateBasedRule.

*/ inline CreateRateBasedRuleRequest& WithMetricName(const Aws::String& value) { SetMetricName(value); return *this;} /** *

A friendly name or description for the metrics for this * RateBasedRule. The name can contain only alphanumeric characters * (A-Z, a-z, 0-9), with maximum length 128 and minimum length one. It can't * contain whitespace or metric names reserved for AWS WAF, including "All" and * "Default_Action." You can't change the name of the metric after you create the * RateBasedRule.

*/ inline CreateRateBasedRuleRequest& WithMetricName(Aws::String&& value) { SetMetricName(std::move(value)); return *this;} /** *

A friendly name or description for the metrics for this * RateBasedRule. The name can contain only alphanumeric characters * (A-Z, a-z, 0-9), with maximum length 128 and minimum length one. It can't * contain whitespace or metric names reserved for AWS WAF, including "All" and * "Default_Action." You can't change the name of the metric after you create the * RateBasedRule.

*/ inline CreateRateBasedRuleRequest& WithMetricName(const char* value) { SetMetricName(value); return *this;} /** *

The field that AWS WAF uses to determine if requests are likely arriving from * a single source and thus subject to rate monitoring. The only valid value for * RateKey is IP. IP indicates that requests * that arrive from the same IP address are subject to the RateLimit * that is specified in the RateBasedRule.

*/ inline const RateKey& GetRateKey() const{ return m_rateKey; } /** *

The field that AWS WAF uses to determine if requests are likely arriving from * a single source and thus subject to rate monitoring. The only valid value for * RateKey is IP. IP indicates that requests * that arrive from the same IP address are subject to the RateLimit * that is specified in the RateBasedRule.

*/ inline bool RateKeyHasBeenSet() const { return m_rateKeyHasBeenSet; } /** *

The field that AWS WAF uses to determine if requests are likely arriving from * a single source and thus subject to rate monitoring. The only valid value for * RateKey is IP. IP indicates that requests * that arrive from the same IP address are subject to the RateLimit * that is specified in the RateBasedRule.

*/ inline void SetRateKey(const RateKey& value) { m_rateKeyHasBeenSet = true; m_rateKey = value; } /** *

The field that AWS WAF uses to determine if requests are likely arriving from * a single source and thus subject to rate monitoring. The only valid value for * RateKey is IP. IP indicates that requests * that arrive from the same IP address are subject to the RateLimit * that is specified in the RateBasedRule.

*/ inline void SetRateKey(RateKey&& value) { m_rateKeyHasBeenSet = true; m_rateKey = std::move(value); } /** *

The field that AWS WAF uses to determine if requests are likely arriving from * a single source and thus subject to rate monitoring. The only valid value for * RateKey is IP. IP indicates that requests * that arrive from the same IP address are subject to the RateLimit * that is specified in the RateBasedRule.

*/ inline CreateRateBasedRuleRequest& WithRateKey(const RateKey& value) { SetRateKey(value); return *this;} /** *

The field that AWS WAF uses to determine if requests are likely arriving from * a single source and thus subject to rate monitoring. The only valid value for * RateKey is IP. IP indicates that requests * that arrive from the same IP address are subject to the RateLimit * that is specified in the RateBasedRule.

*/ inline CreateRateBasedRuleRequest& WithRateKey(RateKey&& value) { SetRateKey(std::move(value)); return *this;} /** *

The maximum number of requests, which have an identical value in the field * that is specified by RateKey, allowed in a five-minute period. If * the number of requests exceeds the RateLimit and the other * predicates specified in the rule are also met, AWS WAF triggers the action that * is specified for this rule.

*/ inline long long GetRateLimit() const{ return m_rateLimit; } /** *

The maximum number of requests, which have an identical value in the field * that is specified by RateKey, allowed in a five-minute period. If * the number of requests exceeds the RateLimit and the other * predicates specified in the rule are also met, AWS WAF triggers the action that * is specified for this rule.

*/ inline bool RateLimitHasBeenSet() const { return m_rateLimitHasBeenSet; } /** *

The maximum number of requests, which have an identical value in the field * that is specified by RateKey, allowed in a five-minute period. If * the number of requests exceeds the RateLimit and the other * predicates specified in the rule are also met, AWS WAF triggers the action that * is specified for this rule.

*/ inline void SetRateLimit(long long value) { m_rateLimitHasBeenSet = true; m_rateLimit = value; } /** *

The maximum number of requests, which have an identical value in the field * that is specified by RateKey, allowed in a five-minute period. If * the number of requests exceeds the RateLimit and the other * predicates specified in the rule are also met, AWS WAF triggers the action that * is specified for this rule.

*/ inline CreateRateBasedRuleRequest& WithRateLimit(long long value) { SetRateLimit(value); return *this;} /** *

The ChangeToken that you used to submit the * CreateRateBasedRule request. You can also use this value to query * the status of the request. For more information, see * GetChangeTokenStatus.

*/ inline const Aws::String& GetChangeToken() const{ return m_changeToken; } /** *

The ChangeToken that you used to submit the * CreateRateBasedRule request. You can also use this value to query * the status of the request. For more information, see * GetChangeTokenStatus.

*/ inline bool ChangeTokenHasBeenSet() const { return m_changeTokenHasBeenSet; } /** *

The ChangeToken that you used to submit the * CreateRateBasedRule request. You can also use this value to query * the status of the request. For more information, see * GetChangeTokenStatus.

*/ inline void SetChangeToken(const Aws::String& value) { m_changeTokenHasBeenSet = true; m_changeToken = value; } /** *

The ChangeToken that you used to submit the * CreateRateBasedRule request. You can also use this value to query * the status of the request. For more information, see * GetChangeTokenStatus.

*/ inline void SetChangeToken(Aws::String&& value) { m_changeTokenHasBeenSet = true; m_changeToken = std::move(value); } /** *

The ChangeToken that you used to submit the * CreateRateBasedRule request. You can also use this value to query * the status of the request. For more information, see * GetChangeTokenStatus.

*/ inline void SetChangeToken(const char* value) { m_changeTokenHasBeenSet = true; m_changeToken.assign(value); } /** *

The ChangeToken that you used to submit the * CreateRateBasedRule request. You can also use this value to query * the status of the request. For more information, see * GetChangeTokenStatus.

*/ inline CreateRateBasedRuleRequest& WithChangeToken(const Aws::String& value) { SetChangeToken(value); return *this;} /** *

The ChangeToken that you used to submit the * CreateRateBasedRule request. You can also use this value to query * the status of the request. For more information, see * GetChangeTokenStatus.

*/ inline CreateRateBasedRuleRequest& WithChangeToken(Aws::String&& value) { SetChangeToken(std::move(value)); return *this;} /** *

The ChangeToken that you used to submit the * CreateRateBasedRule request. You can also use this value to query * the status of the request. For more information, see * GetChangeTokenStatus.

*/ inline CreateRateBasedRuleRequest& WithChangeToken(const char* value) { SetChangeToken(value); return *this;} /** *

*/ inline const Aws::Vector& GetTags() const{ return m_tags; } /** *

*/ inline bool TagsHasBeenSet() const { return m_tagsHasBeenSet; } /** *

*/ inline void SetTags(const Aws::Vector& value) { m_tagsHasBeenSet = true; m_tags = value; } /** *

*/ inline void SetTags(Aws::Vector&& value) { m_tagsHasBeenSet = true; m_tags = std::move(value); } /** *

*/ inline CreateRateBasedRuleRequest& WithTags(const Aws::Vector& value) { SetTags(value); return *this;} /** *

*/ inline CreateRateBasedRuleRequest& WithTags(Aws::Vector&& value) { SetTags(std::move(value)); return *this;} /** *

*/ inline CreateRateBasedRuleRequest& AddTags(const Tag& value) { m_tagsHasBeenSet = true; m_tags.push_back(value); return *this; } /** *

*/ inline CreateRateBasedRuleRequest& AddTags(Tag&& value) { m_tagsHasBeenSet = true; m_tags.push_back(std::move(value)); return *this; } private: Aws::String m_name; bool m_nameHasBeenSet = false; Aws::String m_metricName; bool m_metricNameHasBeenSet = false; RateKey m_rateKey; bool m_rateKeyHasBeenSet = false; long long m_rateLimit; bool m_rateLimitHasBeenSet = false; Aws::String m_changeToken; bool m_changeTokenHasBeenSet = false; Aws::Vector m_tags; bool m_tagsHasBeenSet = false; }; } // namespace Model } // namespace WAF } // namespace Aws