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

Describes the location where the restore job's output is * stored.

See Also:

AWS * API Reference

*/ class OutputLocation { public: AWS_S3_API OutputLocation(); AWS_S3_API OutputLocation(const Aws::Utils::Xml::XmlNode& xmlNode); AWS_S3_API OutputLocation& operator=(const Aws::Utils::Xml::XmlNode& xmlNode); AWS_S3_API void AddToNode(Aws::Utils::Xml::XmlNode& parentNode) const; /** *

Describes an S3 location that will receive the results of the restore * request.

*/ inline const S3Location& GetS3() const{ return m_s3; } /** *

Describes an S3 location that will receive the results of the restore * request.

*/ inline bool S3HasBeenSet() const { return m_s3HasBeenSet; } /** *

Describes an S3 location that will receive the results of the restore * request.

*/ inline void SetS3(const S3Location& value) { m_s3HasBeenSet = true; m_s3 = value; } /** *

Describes an S3 location that will receive the results of the restore * request.

*/ inline void SetS3(S3Location&& value) { m_s3HasBeenSet = true; m_s3 = std::move(value); } /** *

Describes an S3 location that will receive the results of the restore * request.

*/ inline OutputLocation& WithS3(const S3Location& value) { SetS3(value); return *this;} /** *

Describes an S3 location that will receive the results of the restore * request.

*/ inline OutputLocation& WithS3(S3Location&& value) { SetS3(std::move(value)); return *this;} private: S3Location m_s3; bool m_s3HasBeenSet = false; }; } // namespace Model } // namespace S3 } // namespace Aws