This repository has been archived on 2025-09-14. You can view files and clone it, but cannot push or open issues or pull requests.
Files
pxz-hos-client-cpp-module/support/aws-sdk-cpp-master/aws-cpp-sdk-rds/include/aws/rds/model/ScalingConfiguration.h

359 lines
18 KiB
C++

/**
* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
* SPDX-License-Identifier: Apache-2.0.
*/
#pragma once
#include <aws/rds/RDS_EXPORTS.h>
#include <aws/core/utils/memory/stl/AWSStreamFwd.h>
#include <aws/core/utils/memory/stl/AWSString.h>
#include <utility>
namespace Aws
{
namespace Utils
{
namespace Xml
{
class XmlNode;
} // namespace Xml
} // namespace Utils
namespace RDS
{
namespace Model
{
/**
* <p>Contains the scaling configuration of an Aurora Serverless DB cluster.</p>
* <p>For more information, see <a
* href="https://docs.aws.amazon.com/AmazonRDS/latest/AuroraUserGuide/aurora-serverless.html">Using
* Amazon Aurora Serverless</a> in the <i>Amazon Aurora User
* Guide</i>.</p><p><h3>See Also:</h3> <a
* href="http://docs.aws.amazon.com/goto/WebAPI/rds-2014-10-31/ScalingConfiguration">AWS
* API Reference</a></p>
*/
class AWS_RDS_API ScalingConfiguration
{
public:
ScalingConfiguration();
ScalingConfiguration(const Aws::Utils::Xml::XmlNode& xmlNode);
ScalingConfiguration& operator=(const Aws::Utils::Xml::XmlNode& xmlNode);
void OutputToStream(Aws::OStream& ostream, const char* location, unsigned index, const char* locationValue) const;
void OutputToStream(Aws::OStream& oStream, const char* location) const;
/**
* <p>The minimum capacity for an Aurora DB cluster in <code>serverless</code> DB
* engine mode.</p> <p>For Aurora MySQL, valid capacity values are <code>1</code>,
* <code>2</code>, <code>4</code>, <code>8</code>, <code>16</code>,
* <code>32</code>, <code>64</code>, <code>128</code>, and <code>256</code>.</p>
* <p>For Aurora PostgreSQL, valid capacity values are <code>2</code>,
* <code>4</code>, <code>8</code>, <code>16</code>, <code>32</code>,
* <code>64</code>, <code>192</code>, and <code>384</code>.</p> <p>The minimum
* capacity must be less than or equal to the maximum capacity.</p>
*/
inline int GetMinCapacity() const{ return m_minCapacity; }
/**
* <p>The minimum capacity for an Aurora DB cluster in <code>serverless</code> DB
* engine mode.</p> <p>For Aurora MySQL, valid capacity values are <code>1</code>,
* <code>2</code>, <code>4</code>, <code>8</code>, <code>16</code>,
* <code>32</code>, <code>64</code>, <code>128</code>, and <code>256</code>.</p>
* <p>For Aurora PostgreSQL, valid capacity values are <code>2</code>,
* <code>4</code>, <code>8</code>, <code>16</code>, <code>32</code>,
* <code>64</code>, <code>192</code>, and <code>384</code>.</p> <p>The minimum
* capacity must be less than or equal to the maximum capacity.</p>
*/
inline bool MinCapacityHasBeenSet() const { return m_minCapacityHasBeenSet; }
/**
* <p>The minimum capacity for an Aurora DB cluster in <code>serverless</code> DB
* engine mode.</p> <p>For Aurora MySQL, valid capacity values are <code>1</code>,
* <code>2</code>, <code>4</code>, <code>8</code>, <code>16</code>,
* <code>32</code>, <code>64</code>, <code>128</code>, and <code>256</code>.</p>
* <p>For Aurora PostgreSQL, valid capacity values are <code>2</code>,
* <code>4</code>, <code>8</code>, <code>16</code>, <code>32</code>,
* <code>64</code>, <code>192</code>, and <code>384</code>.</p> <p>The minimum
* capacity must be less than or equal to the maximum capacity.</p>
*/
inline void SetMinCapacity(int value) { m_minCapacityHasBeenSet = true; m_minCapacity = value; }
/**
* <p>The minimum capacity for an Aurora DB cluster in <code>serverless</code> DB
* engine mode.</p> <p>For Aurora MySQL, valid capacity values are <code>1</code>,
* <code>2</code>, <code>4</code>, <code>8</code>, <code>16</code>,
* <code>32</code>, <code>64</code>, <code>128</code>, and <code>256</code>.</p>
* <p>For Aurora PostgreSQL, valid capacity values are <code>2</code>,
* <code>4</code>, <code>8</code>, <code>16</code>, <code>32</code>,
* <code>64</code>, <code>192</code>, and <code>384</code>.</p> <p>The minimum
* capacity must be less than or equal to the maximum capacity.</p>
*/
inline ScalingConfiguration& WithMinCapacity(int value) { SetMinCapacity(value); return *this;}
/**
* <p>The maximum capacity for an Aurora DB cluster in <code>serverless</code> DB
* engine mode.</p> <p>For Aurora MySQL, valid capacity values are <code>1</code>,
* <code>2</code>, <code>4</code>, <code>8</code>, <code>16</code>,
* <code>32</code>, <code>64</code>, <code>128</code>, and <code>256</code>.</p>
* <p>For Aurora PostgreSQL, valid capacity values are <code>2</code>,
* <code>4</code>, <code>8</code>, <code>16</code>, <code>32</code>,
* <code>64</code>, <code>192</code>, and <code>384</code>.</p> <p>The maximum
* capacity must be greater than or equal to the minimum capacity.</p>
*/
inline int GetMaxCapacity() const{ return m_maxCapacity; }
/**
* <p>The maximum capacity for an Aurora DB cluster in <code>serverless</code> DB
* engine mode.</p> <p>For Aurora MySQL, valid capacity values are <code>1</code>,
* <code>2</code>, <code>4</code>, <code>8</code>, <code>16</code>,
* <code>32</code>, <code>64</code>, <code>128</code>, and <code>256</code>.</p>
* <p>For Aurora PostgreSQL, valid capacity values are <code>2</code>,
* <code>4</code>, <code>8</code>, <code>16</code>, <code>32</code>,
* <code>64</code>, <code>192</code>, and <code>384</code>.</p> <p>The maximum
* capacity must be greater than or equal to the minimum capacity.</p>
*/
inline bool MaxCapacityHasBeenSet() const { return m_maxCapacityHasBeenSet; }
/**
* <p>The maximum capacity for an Aurora DB cluster in <code>serverless</code> DB
* engine mode.</p> <p>For Aurora MySQL, valid capacity values are <code>1</code>,
* <code>2</code>, <code>4</code>, <code>8</code>, <code>16</code>,
* <code>32</code>, <code>64</code>, <code>128</code>, and <code>256</code>.</p>
* <p>For Aurora PostgreSQL, valid capacity values are <code>2</code>,
* <code>4</code>, <code>8</code>, <code>16</code>, <code>32</code>,
* <code>64</code>, <code>192</code>, and <code>384</code>.</p> <p>The maximum
* capacity must be greater than or equal to the minimum capacity.</p>
*/
inline void SetMaxCapacity(int value) { m_maxCapacityHasBeenSet = true; m_maxCapacity = value; }
/**
* <p>The maximum capacity for an Aurora DB cluster in <code>serverless</code> DB
* engine mode.</p> <p>For Aurora MySQL, valid capacity values are <code>1</code>,
* <code>2</code>, <code>4</code>, <code>8</code>, <code>16</code>,
* <code>32</code>, <code>64</code>, <code>128</code>, and <code>256</code>.</p>
* <p>For Aurora PostgreSQL, valid capacity values are <code>2</code>,
* <code>4</code>, <code>8</code>, <code>16</code>, <code>32</code>,
* <code>64</code>, <code>192</code>, and <code>384</code>.</p> <p>The maximum
* capacity must be greater than or equal to the minimum capacity.</p>
*/
inline ScalingConfiguration& WithMaxCapacity(int value) { SetMaxCapacity(value); return *this;}
/**
* <p>A value that indicates whether to allow or disallow automatic pause for an
* Aurora DB cluster in <code>serverless</code> DB engine mode. A DB cluster can be
* paused only when it's idle (it has no connections).</p> <p>If a DB
* cluster is paused for more than seven days, the DB cluster might be backed up
* with a snapshot. In this case, the DB cluster is restored when there is a
* request to connect to it. </p>
*/
inline bool GetAutoPause() const{ return m_autoPause; }
/**
* <p>A value that indicates whether to allow or disallow automatic pause for an
* Aurora DB cluster in <code>serverless</code> DB engine mode. A DB cluster can be
* paused only when it's idle (it has no connections).</p> <p>If a DB
* cluster is paused for more than seven days, the DB cluster might be backed up
* with a snapshot. In this case, the DB cluster is restored when there is a
* request to connect to it. </p>
*/
inline bool AutoPauseHasBeenSet() const { return m_autoPauseHasBeenSet; }
/**
* <p>A value that indicates whether to allow or disallow automatic pause for an
* Aurora DB cluster in <code>serverless</code> DB engine mode. A DB cluster can be
* paused only when it's idle (it has no connections).</p> <p>If a DB
* cluster is paused for more than seven days, the DB cluster might be backed up
* with a snapshot. In this case, the DB cluster is restored when there is a
* request to connect to it. </p>
*/
inline void SetAutoPause(bool value) { m_autoPauseHasBeenSet = true; m_autoPause = value; }
/**
* <p>A value that indicates whether to allow or disallow automatic pause for an
* Aurora DB cluster in <code>serverless</code> DB engine mode. A DB cluster can be
* paused only when it's idle (it has no connections).</p> <p>If a DB
* cluster is paused for more than seven days, the DB cluster might be backed up
* with a snapshot. In this case, the DB cluster is restored when there is a
* request to connect to it. </p>
*/
inline ScalingConfiguration& WithAutoPause(bool value) { SetAutoPause(value); return *this;}
/**
* <p>The time, in seconds, before an Aurora DB cluster in <code>serverless</code>
* mode is paused.</p>
*/
inline int GetSecondsUntilAutoPause() const{ return m_secondsUntilAutoPause; }
/**
* <p>The time, in seconds, before an Aurora DB cluster in <code>serverless</code>
* mode is paused.</p>
*/
inline bool SecondsUntilAutoPauseHasBeenSet() const { return m_secondsUntilAutoPauseHasBeenSet; }
/**
* <p>The time, in seconds, before an Aurora DB cluster in <code>serverless</code>
* mode is paused.</p>
*/
inline void SetSecondsUntilAutoPause(int value) { m_secondsUntilAutoPauseHasBeenSet = true; m_secondsUntilAutoPause = value; }
/**
* <p>The time, in seconds, before an Aurora DB cluster in <code>serverless</code>
* mode is paused.</p>
*/
inline ScalingConfiguration& WithSecondsUntilAutoPause(int value) { SetSecondsUntilAutoPause(value); return *this;}
/**
* <p>The action to take when the timeout is reached, either
* <code>ForceApplyCapacityChange</code> or
* <code>RollbackCapacityChange</code>.</p> <p>
* <code>ForceApplyCapacityChange</code> sets the capacity to the specified value
* as soon as possible.</p> <p> <code>RollbackCapacityChange</code>, the default,
* ignores the capacity change if a scaling point isn't found in the timeout
* period.</p> <p>If you specify <code>ForceApplyCapacityChange</code>,
* connections that prevent Aurora Serverless from finding a scaling point might be
* dropped.</p> <p>For more information, see <a
* href="https://docs.aws.amazon.com/AmazonRDS/latest/AuroraUserGuide/aurora-serverless.how-it-works.html#aurora-serverless.how-it-works.auto-scaling">
* Autoscaling for Aurora Serverless</a> in the <i>Amazon Aurora User
* Guide</i>.</p>
*/
inline const Aws::String& GetTimeoutAction() const{ return m_timeoutAction; }
/**
* <p>The action to take when the timeout is reached, either
* <code>ForceApplyCapacityChange</code> or
* <code>RollbackCapacityChange</code>.</p> <p>
* <code>ForceApplyCapacityChange</code> sets the capacity to the specified value
* as soon as possible.</p> <p> <code>RollbackCapacityChange</code>, the default,
* ignores the capacity change if a scaling point isn't found in the timeout
* period.</p> <p>If you specify <code>ForceApplyCapacityChange</code>,
* connections that prevent Aurora Serverless from finding a scaling point might be
* dropped.</p> <p>For more information, see <a
* href="https://docs.aws.amazon.com/AmazonRDS/latest/AuroraUserGuide/aurora-serverless.how-it-works.html#aurora-serverless.how-it-works.auto-scaling">
* Autoscaling for Aurora Serverless</a> in the <i>Amazon Aurora User
* Guide</i>.</p>
*/
inline bool TimeoutActionHasBeenSet() const { return m_timeoutActionHasBeenSet; }
/**
* <p>The action to take when the timeout is reached, either
* <code>ForceApplyCapacityChange</code> or
* <code>RollbackCapacityChange</code>.</p> <p>
* <code>ForceApplyCapacityChange</code> sets the capacity to the specified value
* as soon as possible.</p> <p> <code>RollbackCapacityChange</code>, the default,
* ignores the capacity change if a scaling point isn't found in the timeout
* period.</p> <p>If you specify <code>ForceApplyCapacityChange</code>,
* connections that prevent Aurora Serverless from finding a scaling point might be
* dropped.</p> <p>For more information, see <a
* href="https://docs.aws.amazon.com/AmazonRDS/latest/AuroraUserGuide/aurora-serverless.how-it-works.html#aurora-serverless.how-it-works.auto-scaling">
* Autoscaling for Aurora Serverless</a> in the <i>Amazon Aurora User
* Guide</i>.</p>
*/
inline void SetTimeoutAction(const Aws::String& value) { m_timeoutActionHasBeenSet = true; m_timeoutAction = value; }
/**
* <p>The action to take when the timeout is reached, either
* <code>ForceApplyCapacityChange</code> or
* <code>RollbackCapacityChange</code>.</p> <p>
* <code>ForceApplyCapacityChange</code> sets the capacity to the specified value
* as soon as possible.</p> <p> <code>RollbackCapacityChange</code>, the default,
* ignores the capacity change if a scaling point isn't found in the timeout
* period.</p> <p>If you specify <code>ForceApplyCapacityChange</code>,
* connections that prevent Aurora Serverless from finding a scaling point might be
* dropped.</p> <p>For more information, see <a
* href="https://docs.aws.amazon.com/AmazonRDS/latest/AuroraUserGuide/aurora-serverless.how-it-works.html#aurora-serverless.how-it-works.auto-scaling">
* Autoscaling for Aurora Serverless</a> in the <i>Amazon Aurora User
* Guide</i>.</p>
*/
inline void SetTimeoutAction(Aws::String&& value) { m_timeoutActionHasBeenSet = true; m_timeoutAction = std::move(value); }
/**
* <p>The action to take when the timeout is reached, either
* <code>ForceApplyCapacityChange</code> or
* <code>RollbackCapacityChange</code>.</p> <p>
* <code>ForceApplyCapacityChange</code> sets the capacity to the specified value
* as soon as possible.</p> <p> <code>RollbackCapacityChange</code>, the default,
* ignores the capacity change if a scaling point isn't found in the timeout
* period.</p> <p>If you specify <code>ForceApplyCapacityChange</code>,
* connections that prevent Aurora Serverless from finding a scaling point might be
* dropped.</p> <p>For more information, see <a
* href="https://docs.aws.amazon.com/AmazonRDS/latest/AuroraUserGuide/aurora-serverless.how-it-works.html#aurora-serverless.how-it-works.auto-scaling">
* Autoscaling for Aurora Serverless</a> in the <i>Amazon Aurora User
* Guide</i>.</p>
*/
inline void SetTimeoutAction(const char* value) { m_timeoutActionHasBeenSet = true; m_timeoutAction.assign(value); }
/**
* <p>The action to take when the timeout is reached, either
* <code>ForceApplyCapacityChange</code> or
* <code>RollbackCapacityChange</code>.</p> <p>
* <code>ForceApplyCapacityChange</code> sets the capacity to the specified value
* as soon as possible.</p> <p> <code>RollbackCapacityChange</code>, the default,
* ignores the capacity change if a scaling point isn't found in the timeout
* period.</p> <p>If you specify <code>ForceApplyCapacityChange</code>,
* connections that prevent Aurora Serverless from finding a scaling point might be
* dropped.</p> <p>For more information, see <a
* href="https://docs.aws.amazon.com/AmazonRDS/latest/AuroraUserGuide/aurora-serverless.how-it-works.html#aurora-serverless.how-it-works.auto-scaling">
* Autoscaling for Aurora Serverless</a> in the <i>Amazon Aurora User
* Guide</i>.</p>
*/
inline ScalingConfiguration& WithTimeoutAction(const Aws::String& value) { SetTimeoutAction(value); return *this;}
/**
* <p>The action to take when the timeout is reached, either
* <code>ForceApplyCapacityChange</code> or
* <code>RollbackCapacityChange</code>.</p> <p>
* <code>ForceApplyCapacityChange</code> sets the capacity to the specified value
* as soon as possible.</p> <p> <code>RollbackCapacityChange</code>, the default,
* ignores the capacity change if a scaling point isn't found in the timeout
* period.</p> <p>If you specify <code>ForceApplyCapacityChange</code>,
* connections that prevent Aurora Serverless from finding a scaling point might be
* dropped.</p> <p>For more information, see <a
* href="https://docs.aws.amazon.com/AmazonRDS/latest/AuroraUserGuide/aurora-serverless.how-it-works.html#aurora-serverless.how-it-works.auto-scaling">
* Autoscaling for Aurora Serverless</a> in the <i>Amazon Aurora User
* Guide</i>.</p>
*/
inline ScalingConfiguration& WithTimeoutAction(Aws::String&& value) { SetTimeoutAction(std::move(value)); return *this;}
/**
* <p>The action to take when the timeout is reached, either
* <code>ForceApplyCapacityChange</code> or
* <code>RollbackCapacityChange</code>.</p> <p>
* <code>ForceApplyCapacityChange</code> sets the capacity to the specified value
* as soon as possible.</p> <p> <code>RollbackCapacityChange</code>, the default,
* ignores the capacity change if a scaling point isn't found in the timeout
* period.</p> <p>If you specify <code>ForceApplyCapacityChange</code>,
* connections that prevent Aurora Serverless from finding a scaling point might be
* dropped.</p> <p>For more information, see <a
* href="https://docs.aws.amazon.com/AmazonRDS/latest/AuroraUserGuide/aurora-serverless.how-it-works.html#aurora-serverless.how-it-works.auto-scaling">
* Autoscaling for Aurora Serverless</a> in the <i>Amazon Aurora User
* Guide</i>.</p>
*/
inline ScalingConfiguration& WithTimeoutAction(const char* value) { SetTimeoutAction(value); return *this;}
private:
int m_minCapacity;
bool m_minCapacityHasBeenSet;
int m_maxCapacity;
bool m_maxCapacityHasBeenSet;
bool m_autoPause;
bool m_autoPauseHasBeenSet;
int m_secondsUntilAutoPause;
bool m_secondsUntilAutoPauseHasBeenSet;
Aws::String m_timeoutAction;
bool m_timeoutActionHasBeenSet;
};
} // namespace Model
} // namespace RDS
} // namespace Aws