/** * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. * SPDX-License-Identifier: Apache-2.0. */ #pragma once #include #include #include #include namespace Aws { namespace Utils { namespace Xml { class XmlNode; } // namespace Xml } // namespace Utils namespace EC2 { namespace Model { /** *

Describes a state change.

See Also:

AWS API * Reference

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

The reason code for the state change.

*/ inline const Aws::String& GetCode() const{ return m_code; } /** *

The reason code for the state change.

*/ inline bool CodeHasBeenSet() const { return m_codeHasBeenSet; } /** *

The reason code for the state change.

*/ inline void SetCode(const Aws::String& value) { m_codeHasBeenSet = true; m_code = value; } /** *

The reason code for the state change.

*/ inline void SetCode(Aws::String&& value) { m_codeHasBeenSet = true; m_code = std::move(value); } /** *

The reason code for the state change.

*/ inline void SetCode(const char* value) { m_codeHasBeenSet = true; m_code.assign(value); } /** *

The reason code for the state change.

*/ inline StateReason& WithCode(const Aws::String& value) { SetCode(value); return *this;} /** *

The reason code for the state change.

*/ inline StateReason& WithCode(Aws::String&& value) { SetCode(std::move(value)); return *this;} /** *

The reason code for the state change.

*/ inline StateReason& WithCode(const char* value) { SetCode(value); return *this;} /** *

The message for the state change.

  • * Server.InsufficientInstanceCapacity: There was insufficient * capacity available to satisfy the launch request.

  • * Server.InternalError: An internal error caused the instance to * terminate during launch.

  • Server.ScheduledStop: * The instance was stopped due to a scheduled retirement.

  • * Server.SpotInstanceShutdown: The instance was stopped because the * number of Spot requests with a maximum price equal to or higher than the Spot * price exceeded available capacity or because of an increase in the Spot * price.

  • Server.SpotInstanceTermination: The * instance was terminated because the number of Spot requests with a maximum price * equal to or higher than the Spot price exceeded available capacity or because of * an increase in the Spot price.

  • * Client.InstanceInitiatedShutdown: The instance was shut down using * the shutdown -h command from the instance.

  • * Client.InstanceTerminated: The instance was terminated or rebooted * during AMI creation.

  • Client.InternalError: A * client error caused the instance to terminate during launch.

  • * Client.InvalidSnapshot.NotFound: The specified snapshot was not * found.

  • Client.UserInitiatedHibernate: * Hibernation was initiated on the instance.

  • * Client.UserInitiatedShutdown: The instance was shut down using the * Amazon EC2 API.

  • Client.VolumeLimitExceeded: The * limit on the number of EBS volumes or total storage was exceeded. Decrease usage * or request an increase in your account limits.

*/ inline const Aws::String& GetMessage() const{ return m_message; } /** *

The message for the state change.

  • * Server.InsufficientInstanceCapacity: There was insufficient * capacity available to satisfy the launch request.

  • * Server.InternalError: An internal error caused the instance to * terminate during launch.

  • Server.ScheduledStop: * The instance was stopped due to a scheduled retirement.

  • * Server.SpotInstanceShutdown: The instance was stopped because the * number of Spot requests with a maximum price equal to or higher than the Spot * price exceeded available capacity or because of an increase in the Spot * price.

  • Server.SpotInstanceTermination: The * instance was terminated because the number of Spot requests with a maximum price * equal to or higher than the Spot price exceeded available capacity or because of * an increase in the Spot price.

  • * Client.InstanceInitiatedShutdown: The instance was shut down using * the shutdown -h command from the instance.

  • * Client.InstanceTerminated: The instance was terminated or rebooted * during AMI creation.

  • Client.InternalError: A * client error caused the instance to terminate during launch.

  • * Client.InvalidSnapshot.NotFound: The specified snapshot was not * found.

  • Client.UserInitiatedHibernate: * Hibernation was initiated on the instance.

  • * Client.UserInitiatedShutdown: The instance was shut down using the * Amazon EC2 API.

  • Client.VolumeLimitExceeded: The * limit on the number of EBS volumes or total storage was exceeded. Decrease usage * or request an increase in your account limits.

*/ inline bool MessageHasBeenSet() const { return m_messageHasBeenSet; } /** *

The message for the state change.

  • * Server.InsufficientInstanceCapacity: There was insufficient * capacity available to satisfy the launch request.

  • * Server.InternalError: An internal error caused the instance to * terminate during launch.

  • Server.ScheduledStop: * The instance was stopped due to a scheduled retirement.

  • * Server.SpotInstanceShutdown: The instance was stopped because the * number of Spot requests with a maximum price equal to or higher than the Spot * price exceeded available capacity or because of an increase in the Spot * price.

  • Server.SpotInstanceTermination: The * instance was terminated because the number of Spot requests with a maximum price * equal to or higher than the Spot price exceeded available capacity or because of * an increase in the Spot price.

  • * Client.InstanceInitiatedShutdown: The instance was shut down using * the shutdown -h command from the instance.

  • * Client.InstanceTerminated: The instance was terminated or rebooted * during AMI creation.

  • Client.InternalError: A * client error caused the instance to terminate during launch.

  • * Client.InvalidSnapshot.NotFound: The specified snapshot was not * found.

  • Client.UserInitiatedHibernate: * Hibernation was initiated on the instance.

  • * Client.UserInitiatedShutdown: The instance was shut down using the * Amazon EC2 API.

  • Client.VolumeLimitExceeded: The * limit on the number of EBS volumes or total storage was exceeded. Decrease usage * or request an increase in your account limits.

*/ inline void SetMessage(const Aws::String& value) { m_messageHasBeenSet = true; m_message = value; } /** *

The message for the state change.

  • * Server.InsufficientInstanceCapacity: There was insufficient * capacity available to satisfy the launch request.

  • * Server.InternalError: An internal error caused the instance to * terminate during launch.

  • Server.ScheduledStop: * The instance was stopped due to a scheduled retirement.

  • * Server.SpotInstanceShutdown: The instance was stopped because the * number of Spot requests with a maximum price equal to or higher than the Spot * price exceeded available capacity or because of an increase in the Spot * price.

  • Server.SpotInstanceTermination: The * instance was terminated because the number of Spot requests with a maximum price * equal to or higher than the Spot price exceeded available capacity or because of * an increase in the Spot price.

  • * Client.InstanceInitiatedShutdown: The instance was shut down using * the shutdown -h command from the instance.

  • * Client.InstanceTerminated: The instance was terminated or rebooted * during AMI creation.

  • Client.InternalError: A * client error caused the instance to terminate during launch.

  • * Client.InvalidSnapshot.NotFound: The specified snapshot was not * found.

  • Client.UserInitiatedHibernate: * Hibernation was initiated on the instance.

  • * Client.UserInitiatedShutdown: The instance was shut down using the * Amazon EC2 API.

  • Client.VolumeLimitExceeded: The * limit on the number of EBS volumes or total storage was exceeded. Decrease usage * or request an increase in your account limits.

*/ inline void SetMessage(Aws::String&& value) { m_messageHasBeenSet = true; m_message = std::move(value); } /** *

The message for the state change.

  • * Server.InsufficientInstanceCapacity: There was insufficient * capacity available to satisfy the launch request.

  • * Server.InternalError: An internal error caused the instance to * terminate during launch.

  • Server.ScheduledStop: * The instance was stopped due to a scheduled retirement.

  • * Server.SpotInstanceShutdown: The instance was stopped because the * number of Spot requests with a maximum price equal to or higher than the Spot * price exceeded available capacity or because of an increase in the Spot * price.

  • Server.SpotInstanceTermination: The * instance was terminated because the number of Spot requests with a maximum price * equal to or higher than the Spot price exceeded available capacity or because of * an increase in the Spot price.

  • * Client.InstanceInitiatedShutdown: The instance was shut down using * the shutdown -h command from the instance.

  • * Client.InstanceTerminated: The instance was terminated or rebooted * during AMI creation.

  • Client.InternalError: A * client error caused the instance to terminate during launch.

  • * Client.InvalidSnapshot.NotFound: The specified snapshot was not * found.

  • Client.UserInitiatedHibernate: * Hibernation was initiated on the instance.

  • * Client.UserInitiatedShutdown: The instance was shut down using the * Amazon EC2 API.

  • Client.VolumeLimitExceeded: The * limit on the number of EBS volumes or total storage was exceeded. Decrease usage * or request an increase in your account limits.

*/ inline void SetMessage(const char* value) { m_messageHasBeenSet = true; m_message.assign(value); } /** *

The message for the state change.

  • * Server.InsufficientInstanceCapacity: There was insufficient * capacity available to satisfy the launch request.

  • * Server.InternalError: An internal error caused the instance to * terminate during launch.

  • Server.ScheduledStop: * The instance was stopped due to a scheduled retirement.

  • * Server.SpotInstanceShutdown: The instance was stopped because the * number of Spot requests with a maximum price equal to or higher than the Spot * price exceeded available capacity or because of an increase in the Spot * price.

  • Server.SpotInstanceTermination: The * instance was terminated because the number of Spot requests with a maximum price * equal to or higher than the Spot price exceeded available capacity or because of * an increase in the Spot price.

  • * Client.InstanceInitiatedShutdown: The instance was shut down using * the shutdown -h command from the instance.

  • * Client.InstanceTerminated: The instance was terminated or rebooted * during AMI creation.

  • Client.InternalError: A * client error caused the instance to terminate during launch.

  • * Client.InvalidSnapshot.NotFound: The specified snapshot was not * found.

  • Client.UserInitiatedHibernate: * Hibernation was initiated on the instance.

  • * Client.UserInitiatedShutdown: The instance was shut down using the * Amazon EC2 API.

  • Client.VolumeLimitExceeded: The * limit on the number of EBS volumes or total storage was exceeded. Decrease usage * or request an increase in your account limits.

*/ inline StateReason& WithMessage(const Aws::String& value) { SetMessage(value); return *this;} /** *

The message for the state change.

  • * Server.InsufficientInstanceCapacity: There was insufficient * capacity available to satisfy the launch request.

  • * Server.InternalError: An internal error caused the instance to * terminate during launch.

  • Server.ScheduledStop: * The instance was stopped due to a scheduled retirement.

  • * Server.SpotInstanceShutdown: The instance was stopped because the * number of Spot requests with a maximum price equal to or higher than the Spot * price exceeded available capacity or because of an increase in the Spot * price.

  • Server.SpotInstanceTermination: The * instance was terminated because the number of Spot requests with a maximum price * equal to or higher than the Spot price exceeded available capacity or because of * an increase in the Spot price.

  • * Client.InstanceInitiatedShutdown: The instance was shut down using * the shutdown -h command from the instance.

  • * Client.InstanceTerminated: The instance was terminated or rebooted * during AMI creation.

  • Client.InternalError: A * client error caused the instance to terminate during launch.

  • * Client.InvalidSnapshot.NotFound: The specified snapshot was not * found.

  • Client.UserInitiatedHibernate: * Hibernation was initiated on the instance.

  • * Client.UserInitiatedShutdown: The instance was shut down using the * Amazon EC2 API.

  • Client.VolumeLimitExceeded: The * limit on the number of EBS volumes or total storage was exceeded. Decrease usage * or request an increase in your account limits.

*/ inline StateReason& WithMessage(Aws::String&& value) { SetMessage(std::move(value)); return *this;} /** *

The message for the state change.

  • * Server.InsufficientInstanceCapacity: There was insufficient * capacity available to satisfy the launch request.

  • * Server.InternalError: An internal error caused the instance to * terminate during launch.

  • Server.ScheduledStop: * The instance was stopped due to a scheduled retirement.

  • * Server.SpotInstanceShutdown: The instance was stopped because the * number of Spot requests with a maximum price equal to or higher than the Spot * price exceeded available capacity or because of an increase in the Spot * price.

  • Server.SpotInstanceTermination: The * instance was terminated because the number of Spot requests with a maximum price * equal to or higher than the Spot price exceeded available capacity or because of * an increase in the Spot price.

  • * Client.InstanceInitiatedShutdown: The instance was shut down using * the shutdown -h command from the instance.

  • * Client.InstanceTerminated: The instance was terminated or rebooted * during AMI creation.

  • Client.InternalError: A * client error caused the instance to terminate during launch.

  • * Client.InvalidSnapshot.NotFound: The specified snapshot was not * found.

  • Client.UserInitiatedHibernate: * Hibernation was initiated on the instance.

  • * Client.UserInitiatedShutdown: The instance was shut down using the * Amazon EC2 API.

  • Client.VolumeLimitExceeded: The * limit on the number of EBS volumes or total storage was exceeded. Decrease usage * or request an increase in your account limits.

*/ inline StateReason& WithMessage(const char* value) { SetMessage(value); return *this;} private: Aws::String m_code; bool m_codeHasBeenSet = false; Aws::String m_message; bool m_messageHasBeenSet = false; }; } // namespace Model } // namespace EC2 } // namespace Aws