/** * 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 AutoScaling { namespace Model { /** */ class GetPredictiveScalingForecastRequest : public AutoScalingRequest { public: AWS_AUTOSCALING_API GetPredictiveScalingForecastRequest(); // 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 "GetPredictiveScalingForecast"; } AWS_AUTOSCALING_API Aws::String SerializePayload() const override; protected: AWS_AUTOSCALING_API void DumpBodyToUrl(Aws::Http::URI& uri ) const override; public: /** *

The name of the Auto Scaling group.

*/ inline const Aws::String& GetAutoScalingGroupName() const{ return m_autoScalingGroupName; } /** *

The name of the Auto Scaling group.

*/ inline bool AutoScalingGroupNameHasBeenSet() const { return m_autoScalingGroupNameHasBeenSet; } /** *

The name of the Auto Scaling group.

*/ inline void SetAutoScalingGroupName(const Aws::String& value) { m_autoScalingGroupNameHasBeenSet = true; m_autoScalingGroupName = value; } /** *

The name of the Auto Scaling group.

*/ inline void SetAutoScalingGroupName(Aws::String&& value) { m_autoScalingGroupNameHasBeenSet = true; m_autoScalingGroupName = std::move(value); } /** *

The name of the Auto Scaling group.

*/ inline void SetAutoScalingGroupName(const char* value) { m_autoScalingGroupNameHasBeenSet = true; m_autoScalingGroupName.assign(value); } /** *

The name of the Auto Scaling group.

*/ inline GetPredictiveScalingForecastRequest& WithAutoScalingGroupName(const Aws::String& value) { SetAutoScalingGroupName(value); return *this;} /** *

The name of the Auto Scaling group.

*/ inline GetPredictiveScalingForecastRequest& WithAutoScalingGroupName(Aws::String&& value) { SetAutoScalingGroupName(std::move(value)); return *this;} /** *

The name of the Auto Scaling group.

*/ inline GetPredictiveScalingForecastRequest& WithAutoScalingGroupName(const char* value) { SetAutoScalingGroupName(value); return *this;} /** *

The name of the policy.

*/ inline const Aws::String& GetPolicyName() const{ return m_policyName; } /** *

The name of the policy.

*/ inline bool PolicyNameHasBeenSet() const { return m_policyNameHasBeenSet; } /** *

The name of the policy.

*/ inline void SetPolicyName(const Aws::String& value) { m_policyNameHasBeenSet = true; m_policyName = value; } /** *

The name of the policy.

*/ inline void SetPolicyName(Aws::String&& value) { m_policyNameHasBeenSet = true; m_policyName = std::move(value); } /** *

The name of the policy.

*/ inline void SetPolicyName(const char* value) { m_policyNameHasBeenSet = true; m_policyName.assign(value); } /** *

The name of the policy.

*/ inline GetPredictiveScalingForecastRequest& WithPolicyName(const Aws::String& value) { SetPolicyName(value); return *this;} /** *

The name of the policy.

*/ inline GetPredictiveScalingForecastRequest& WithPolicyName(Aws::String&& value) { SetPolicyName(std::move(value)); return *this;} /** *

The name of the policy.

*/ inline GetPredictiveScalingForecastRequest& WithPolicyName(const char* value) { SetPolicyName(value); return *this;} /** *

The inclusive start time of the time range for the forecast data to get. At * most, the date and time can be one year before the current date and time.

*/ inline const Aws::Utils::DateTime& GetStartTime() const{ return m_startTime; } /** *

The inclusive start time of the time range for the forecast data to get. At * most, the date and time can be one year before the current date and time.

*/ inline bool StartTimeHasBeenSet() const { return m_startTimeHasBeenSet; } /** *

The inclusive start time of the time range for the forecast data to get. At * most, the date and time can be one year before the current date and time.

*/ inline void SetStartTime(const Aws::Utils::DateTime& value) { m_startTimeHasBeenSet = true; m_startTime = value; } /** *

The inclusive start time of the time range for the forecast data to get. At * most, the date and time can be one year before the current date and time.

*/ inline void SetStartTime(Aws::Utils::DateTime&& value) { m_startTimeHasBeenSet = true; m_startTime = std::move(value); } /** *

The inclusive start time of the time range for the forecast data to get. At * most, the date and time can be one year before the current date and time.

*/ inline GetPredictiveScalingForecastRequest& WithStartTime(const Aws::Utils::DateTime& value) { SetStartTime(value); return *this;} /** *

The inclusive start time of the time range for the forecast data to get. At * most, the date and time can be one year before the current date and time.

*/ inline GetPredictiveScalingForecastRequest& WithStartTime(Aws::Utils::DateTime&& value) { SetStartTime(std::move(value)); return *this;} /** *

The exclusive end time of the time range for the forecast data to get. The * maximum time duration between the start and end time is 30 days.

*

Although this parameter can accept a date and time that is more than two days * in the future, the availability of forecast data has limits. Amazon EC2 Auto * Scaling only issues forecasts for periods of two days in advance.

*/ inline const Aws::Utils::DateTime& GetEndTime() const{ return m_endTime; } /** *

The exclusive end time of the time range for the forecast data to get. The * maximum time duration between the start and end time is 30 days.

*

Although this parameter can accept a date and time that is more than two days * in the future, the availability of forecast data has limits. Amazon EC2 Auto * Scaling only issues forecasts for periods of two days in advance.

*/ inline bool EndTimeHasBeenSet() const { return m_endTimeHasBeenSet; } /** *

The exclusive end time of the time range for the forecast data to get. The * maximum time duration between the start and end time is 30 days.

*

Although this parameter can accept a date and time that is more than two days * in the future, the availability of forecast data has limits. Amazon EC2 Auto * Scaling only issues forecasts for periods of two days in advance.

*/ inline void SetEndTime(const Aws::Utils::DateTime& value) { m_endTimeHasBeenSet = true; m_endTime = value; } /** *

The exclusive end time of the time range for the forecast data to get. The * maximum time duration between the start and end time is 30 days.

*

Although this parameter can accept a date and time that is more than two days * in the future, the availability of forecast data has limits. Amazon EC2 Auto * Scaling only issues forecasts for periods of two days in advance.

*/ inline void SetEndTime(Aws::Utils::DateTime&& value) { m_endTimeHasBeenSet = true; m_endTime = std::move(value); } /** *

The exclusive end time of the time range for the forecast data to get. The * maximum time duration between the start and end time is 30 days.

*

Although this parameter can accept a date and time that is more than two days * in the future, the availability of forecast data has limits. Amazon EC2 Auto * Scaling only issues forecasts for periods of two days in advance.

*/ inline GetPredictiveScalingForecastRequest& WithEndTime(const Aws::Utils::DateTime& value) { SetEndTime(value); return *this;} /** *

The exclusive end time of the time range for the forecast data to get. The * maximum time duration between the start and end time is 30 days.

*

Although this parameter can accept a date and time that is more than two days * in the future, the availability of forecast data has limits. Amazon EC2 Auto * Scaling only issues forecasts for periods of two days in advance.

*/ inline GetPredictiveScalingForecastRequest& WithEndTime(Aws::Utils::DateTime&& value) { SetEndTime(std::move(value)); return *this;} private: Aws::String m_autoScalingGroupName; bool m_autoScalingGroupNameHasBeenSet = false; Aws::String m_policyName; bool m_policyNameHasBeenSet = false; Aws::Utils::DateTime m_startTime; bool m_startTimeHasBeenSet = false; Aws::Utils::DateTime m_endTime; bool m_endTimeHasBeenSet = false; }; } // namespace Model } // namespace AutoScaling } // namespace Aws