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

Describes the format and location for the export task.

See * Also:

AWS * API Reference

*/ class ExportToS3Task { public: AWS_EC2_API ExportToS3Task(); AWS_EC2_API ExportToS3Task(const Aws::Utils::Xml::XmlNode& xmlNode); AWS_EC2_API ExportToS3Task& 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 container format used to combine disk images with metadata (such as OVF). * If absent, only the disk image is exported.

*/ inline const ContainerFormat& GetContainerFormat() const{ return m_containerFormat; } /** *

The container format used to combine disk images with metadata (such as OVF). * If absent, only the disk image is exported.

*/ inline bool ContainerFormatHasBeenSet() const { return m_containerFormatHasBeenSet; } /** *

The container format used to combine disk images with metadata (such as OVF). * If absent, only the disk image is exported.

*/ inline void SetContainerFormat(const ContainerFormat& value) { m_containerFormatHasBeenSet = true; m_containerFormat = value; } /** *

The container format used to combine disk images with metadata (such as OVF). * If absent, only the disk image is exported.

*/ inline void SetContainerFormat(ContainerFormat&& value) { m_containerFormatHasBeenSet = true; m_containerFormat = std::move(value); } /** *

The container format used to combine disk images with metadata (such as OVF). * If absent, only the disk image is exported.

*/ inline ExportToS3Task& WithContainerFormat(const ContainerFormat& value) { SetContainerFormat(value); return *this;} /** *

The container format used to combine disk images with metadata (such as OVF). * If absent, only the disk image is exported.

*/ inline ExportToS3Task& WithContainerFormat(ContainerFormat&& value) { SetContainerFormat(std::move(value)); return *this;} /** *

The format for the exported image.

*/ inline const DiskImageFormat& GetDiskImageFormat() const{ return m_diskImageFormat; } /** *

The format for the exported image.

*/ inline bool DiskImageFormatHasBeenSet() const { return m_diskImageFormatHasBeenSet; } /** *

The format for the exported image.

*/ inline void SetDiskImageFormat(const DiskImageFormat& value) { m_diskImageFormatHasBeenSet = true; m_diskImageFormat = value; } /** *

The format for the exported image.

*/ inline void SetDiskImageFormat(DiskImageFormat&& value) { m_diskImageFormatHasBeenSet = true; m_diskImageFormat = std::move(value); } /** *

The format for the exported image.

*/ inline ExportToS3Task& WithDiskImageFormat(const DiskImageFormat& value) { SetDiskImageFormat(value); return *this;} /** *

The format for the exported image.

*/ inline ExportToS3Task& WithDiskImageFormat(DiskImageFormat&& value) { SetDiskImageFormat(std::move(value)); return *this;} /** *

The Amazon S3 bucket for the destination image. The destination bucket must * exist and have an access control list (ACL) attached that specifies the * Region-specific canonical account ID for the Grantee. For more * information about the ACL to your S3 bucket, see Prerequisites * in the VM Import/Export User Guide.

*/ inline const Aws::String& GetS3Bucket() const{ return m_s3Bucket; } /** *

The Amazon S3 bucket for the destination image. The destination bucket must * exist and have an access control list (ACL) attached that specifies the * Region-specific canonical account ID for the Grantee. For more * information about the ACL to your S3 bucket, see Prerequisites * in the VM Import/Export User Guide.

*/ inline bool S3BucketHasBeenSet() const { return m_s3BucketHasBeenSet; } /** *

The Amazon S3 bucket for the destination image. The destination bucket must * exist and have an access control list (ACL) attached that specifies the * Region-specific canonical account ID for the Grantee. For more * information about the ACL to your S3 bucket, see Prerequisites * in the VM Import/Export User Guide.

*/ inline void SetS3Bucket(const Aws::String& value) { m_s3BucketHasBeenSet = true; m_s3Bucket = value; } /** *

The Amazon S3 bucket for the destination image. The destination bucket must * exist and have an access control list (ACL) attached that specifies the * Region-specific canonical account ID for the Grantee. For more * information about the ACL to your S3 bucket, see Prerequisites * in the VM Import/Export User Guide.

*/ inline void SetS3Bucket(Aws::String&& value) { m_s3BucketHasBeenSet = true; m_s3Bucket = std::move(value); } /** *

The Amazon S3 bucket for the destination image. The destination bucket must * exist and have an access control list (ACL) attached that specifies the * Region-specific canonical account ID for the Grantee. For more * information about the ACL to your S3 bucket, see Prerequisites * in the VM Import/Export User Guide.

*/ inline void SetS3Bucket(const char* value) { m_s3BucketHasBeenSet = true; m_s3Bucket.assign(value); } /** *

The Amazon S3 bucket for the destination image. The destination bucket must * exist and have an access control list (ACL) attached that specifies the * Region-specific canonical account ID for the Grantee. For more * information about the ACL to your S3 bucket, see Prerequisites * in the VM Import/Export User Guide.

*/ inline ExportToS3Task& WithS3Bucket(const Aws::String& value) { SetS3Bucket(value); return *this;} /** *

The Amazon S3 bucket for the destination image. The destination bucket must * exist and have an access control list (ACL) attached that specifies the * Region-specific canonical account ID for the Grantee. For more * information about the ACL to your S3 bucket, see Prerequisites * in the VM Import/Export User Guide.

*/ inline ExportToS3Task& WithS3Bucket(Aws::String&& value) { SetS3Bucket(std::move(value)); return *this;} /** *

The Amazon S3 bucket for the destination image. The destination bucket must * exist and have an access control list (ACL) attached that specifies the * Region-specific canonical account ID for the Grantee. For more * information about the ACL to your S3 bucket, see Prerequisites * in the VM Import/Export User Guide.

*/ inline ExportToS3Task& WithS3Bucket(const char* value) { SetS3Bucket(value); return *this;} /** *

The encryption key for your S3 bucket.

*/ inline const Aws::String& GetS3Key() const{ return m_s3Key; } /** *

The encryption key for your S3 bucket.

*/ inline bool S3KeyHasBeenSet() const { return m_s3KeyHasBeenSet; } /** *

The encryption key for your S3 bucket.

*/ inline void SetS3Key(const Aws::String& value) { m_s3KeyHasBeenSet = true; m_s3Key = value; } /** *

The encryption key for your S3 bucket.

*/ inline void SetS3Key(Aws::String&& value) { m_s3KeyHasBeenSet = true; m_s3Key = std::move(value); } /** *

The encryption key for your S3 bucket.

*/ inline void SetS3Key(const char* value) { m_s3KeyHasBeenSet = true; m_s3Key.assign(value); } /** *

The encryption key for your S3 bucket.

*/ inline ExportToS3Task& WithS3Key(const Aws::String& value) { SetS3Key(value); return *this;} /** *

The encryption key for your S3 bucket.

*/ inline ExportToS3Task& WithS3Key(Aws::String&& value) { SetS3Key(std::move(value)); return *this;} /** *

The encryption key for your S3 bucket.

*/ inline ExportToS3Task& WithS3Key(const char* value) { SetS3Key(value); return *this;} private: ContainerFormat m_containerFormat; bool m_containerFormatHasBeenSet = false; DiskImageFormat m_diskImageFormat; bool m_diskImageFormatHasBeenSet = false; Aws::String m_s3Bucket; bool m_s3BucketHasBeenSet = false; Aws::String m_s3Key; bool m_s3KeyHasBeenSet = false; }; } // namespace Model } // namespace EC2 } // namespace Aws