/** * 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 Utils { namespace Xml { class XmlNode; } // namespace Xml } // namespace Utils namespace AutoScaling { namespace Model { /** *

Describes a custom load metric for a predictive scaling policy.

See * Also:

AWS * API Reference

*/ class PredictiveScalingCustomizedLoadMetric { public: AWS_AUTOSCALING_API PredictiveScalingCustomizedLoadMetric(); AWS_AUTOSCALING_API PredictiveScalingCustomizedLoadMetric(const Aws::Utils::Xml::XmlNode& xmlNode); AWS_AUTOSCALING_API PredictiveScalingCustomizedLoadMetric& operator=(const Aws::Utils::Xml::XmlNode& xmlNode); AWS_AUTOSCALING_API void OutputToStream(Aws::OStream& ostream, const char* location, unsigned index, const char* locationValue) const; AWS_AUTOSCALING_API void OutputToStream(Aws::OStream& oStream, const char* location) const; /** *

One or more metric data queries to provide the data points for a load metric. * Use multiple metric data queries only if you are performing a math expression on * returned data.

*/ inline const Aws::Vector& GetMetricDataQueries() const{ return m_metricDataQueries; } /** *

One or more metric data queries to provide the data points for a load metric. * Use multiple metric data queries only if you are performing a math expression on * returned data.

*/ inline bool MetricDataQueriesHasBeenSet() const { return m_metricDataQueriesHasBeenSet; } /** *

One or more metric data queries to provide the data points for a load metric. * Use multiple metric data queries only if you are performing a math expression on * returned data.

*/ inline void SetMetricDataQueries(const Aws::Vector& value) { m_metricDataQueriesHasBeenSet = true; m_metricDataQueries = value; } /** *

One or more metric data queries to provide the data points for a load metric. * Use multiple metric data queries only if you are performing a math expression on * returned data.

*/ inline void SetMetricDataQueries(Aws::Vector&& value) { m_metricDataQueriesHasBeenSet = true; m_metricDataQueries = std::move(value); } /** *

One or more metric data queries to provide the data points for a load metric. * Use multiple metric data queries only if you are performing a math expression on * returned data.

*/ inline PredictiveScalingCustomizedLoadMetric& WithMetricDataQueries(const Aws::Vector& value) { SetMetricDataQueries(value); return *this;} /** *

One or more metric data queries to provide the data points for a load metric. * Use multiple metric data queries only if you are performing a math expression on * returned data.

*/ inline PredictiveScalingCustomizedLoadMetric& WithMetricDataQueries(Aws::Vector&& value) { SetMetricDataQueries(std::move(value)); return *this;} /** *

One or more metric data queries to provide the data points for a load metric. * Use multiple metric data queries only if you are performing a math expression on * returned data.

*/ inline PredictiveScalingCustomizedLoadMetric& AddMetricDataQueries(const MetricDataQuery& value) { m_metricDataQueriesHasBeenSet = true; m_metricDataQueries.push_back(value); return *this; } /** *

One or more metric data queries to provide the data points for a load metric. * Use multiple metric data queries only if you are performing a math expression on * returned data.

*/ inline PredictiveScalingCustomizedLoadMetric& AddMetricDataQueries(MetricDataQuery&& value) { m_metricDataQueriesHasBeenSet = true; m_metricDataQueries.push_back(std::move(value)); return *this; } private: Aws::Vector m_metricDataQueries; bool m_metricDataQueriesHasBeenSet = false; }; } // namespace Model } // namespace AutoScaling } // namespace Aws