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

The defining characteristics of a specific version of an Image Builder * image.

See Also:

AWS * API Reference

*/ class ImageVersion { public: AWS_IMAGEBUILDER_API ImageVersion(); AWS_IMAGEBUILDER_API ImageVersion(Aws::Utils::Json::JsonView jsonValue); AWS_IMAGEBUILDER_API ImageVersion& operator=(Aws::Utils::Json::JsonView jsonValue); AWS_IMAGEBUILDER_API Aws::Utils::Json::JsonValue Jsonize() const; /** *

The Amazon Resource Name (ARN) of a specific version of an Image Builder * image.

Semantic versioning is included in each object's Amazon * Resource Name (ARN), at the level that applies to that object as follows:

*
  1. Versionless ARNs and Name ARNs do not include specific values in * any of the nodes. The nodes are either left off entirely, or they are specified * as wildcards, for example: x.x.x.

  2. Version ARNs have only the * first three nodes: <major>.<minor>.<patch>

  3. *

    Build version ARNs have all four nodes, and point to a specific build for a * specific version of an object.

*/ inline const Aws::String& GetArn() const{ return m_arn; } /** *

The Amazon Resource Name (ARN) of a specific version of an Image Builder * image.

Semantic versioning is included in each object's Amazon * Resource Name (ARN), at the level that applies to that object as follows:

*
  1. Versionless ARNs and Name ARNs do not include specific values in * any of the nodes. The nodes are either left off entirely, or they are specified * as wildcards, for example: x.x.x.

  2. Version ARNs have only the * first three nodes: <major>.<minor>.<patch>

  3. *

    Build version ARNs have all four nodes, and point to a specific build for a * specific version of an object.

*/ inline bool ArnHasBeenSet() const { return m_arnHasBeenSet; } /** *

The Amazon Resource Name (ARN) of a specific version of an Image Builder * image.

Semantic versioning is included in each object's Amazon * Resource Name (ARN), at the level that applies to that object as follows:

*
  1. Versionless ARNs and Name ARNs do not include specific values in * any of the nodes. The nodes are either left off entirely, or they are specified * as wildcards, for example: x.x.x.

  2. Version ARNs have only the * first three nodes: <major>.<minor>.<patch>

  3. *

    Build version ARNs have all four nodes, and point to a specific build for a * specific version of an object.

*/ inline void SetArn(const Aws::String& value) { m_arnHasBeenSet = true; m_arn = value; } /** *

The Amazon Resource Name (ARN) of a specific version of an Image Builder * image.

Semantic versioning is included in each object's Amazon * Resource Name (ARN), at the level that applies to that object as follows:

*
  1. Versionless ARNs and Name ARNs do not include specific values in * any of the nodes. The nodes are either left off entirely, or they are specified * as wildcards, for example: x.x.x.

  2. Version ARNs have only the * first three nodes: <major>.<minor>.<patch>

  3. *

    Build version ARNs have all four nodes, and point to a specific build for a * specific version of an object.

*/ inline void SetArn(Aws::String&& value) { m_arnHasBeenSet = true; m_arn = std::move(value); } /** *

The Amazon Resource Name (ARN) of a specific version of an Image Builder * image.

Semantic versioning is included in each object's Amazon * Resource Name (ARN), at the level that applies to that object as follows:

*
  1. Versionless ARNs and Name ARNs do not include specific values in * any of the nodes. The nodes are either left off entirely, or they are specified * as wildcards, for example: x.x.x.

  2. Version ARNs have only the * first three nodes: <major>.<minor>.<patch>

  3. *

    Build version ARNs have all four nodes, and point to a specific build for a * specific version of an object.

*/ inline void SetArn(const char* value) { m_arnHasBeenSet = true; m_arn.assign(value); } /** *

The Amazon Resource Name (ARN) of a specific version of an Image Builder * image.

Semantic versioning is included in each object's Amazon * Resource Name (ARN), at the level that applies to that object as follows:

*
  1. Versionless ARNs and Name ARNs do not include specific values in * any of the nodes. The nodes are either left off entirely, or they are specified * as wildcards, for example: x.x.x.

  2. Version ARNs have only the * first three nodes: <major>.<minor>.<patch>

  3. *

    Build version ARNs have all four nodes, and point to a specific build for a * specific version of an object.

*/ inline ImageVersion& WithArn(const Aws::String& value) { SetArn(value); return *this;} /** *

The Amazon Resource Name (ARN) of a specific version of an Image Builder * image.

Semantic versioning is included in each object's Amazon * Resource Name (ARN), at the level that applies to that object as follows:

*
  1. Versionless ARNs and Name ARNs do not include specific values in * any of the nodes. The nodes are either left off entirely, or they are specified * as wildcards, for example: x.x.x.

  2. Version ARNs have only the * first three nodes: <major>.<minor>.<patch>

  3. *

    Build version ARNs have all four nodes, and point to a specific build for a * specific version of an object.

*/ inline ImageVersion& WithArn(Aws::String&& value) { SetArn(std::move(value)); return *this;} /** *

The Amazon Resource Name (ARN) of a specific version of an Image Builder * image.

Semantic versioning is included in each object's Amazon * Resource Name (ARN), at the level that applies to that object as follows:

*
  1. Versionless ARNs and Name ARNs do not include specific values in * any of the nodes. The nodes are either left off entirely, or they are specified * as wildcards, for example: x.x.x.

  2. Version ARNs have only the * first three nodes: <major>.<minor>.<patch>

  3. *

    Build version ARNs have all four nodes, and point to a specific build for a * specific version of an object.

*/ inline ImageVersion& WithArn(const char* value) { SetArn(value); return *this;} /** *

The name of this specific version of an Image Builder image.

*/ inline const Aws::String& GetName() const{ return m_name; } /** *

The name of this specific version of an Image Builder image.

*/ inline bool NameHasBeenSet() const { return m_nameHasBeenSet; } /** *

The name of this specific version of an Image Builder image.

*/ inline void SetName(const Aws::String& value) { m_nameHasBeenSet = true; m_name = value; } /** *

The name of this specific version of an Image Builder image.

*/ inline void SetName(Aws::String&& value) { m_nameHasBeenSet = true; m_name = std::move(value); } /** *

The name of this specific version of an Image Builder image.

*/ inline void SetName(const char* value) { m_nameHasBeenSet = true; m_name.assign(value); } /** *

The name of this specific version of an Image Builder image.

*/ inline ImageVersion& WithName(const Aws::String& value) { SetName(value); return *this;} /** *

The name of this specific version of an Image Builder image.

*/ inline ImageVersion& WithName(Aws::String&& value) { SetName(std::move(value)); return *this;} /** *

The name of this specific version of an Image Builder image.

*/ inline ImageVersion& WithName(const char* value) { SetName(value); return *this;} /** *

Specifies whether this image produces an AMI or a container image.

*/ inline const ImageType& GetType() const{ return m_type; } /** *

Specifies whether this image produces an AMI or a container image.

*/ inline bool TypeHasBeenSet() const { return m_typeHasBeenSet; } /** *

Specifies whether this image produces an AMI or a container image.

*/ inline void SetType(const ImageType& value) { m_typeHasBeenSet = true; m_type = value; } /** *

Specifies whether this image produces an AMI or a container image.

*/ inline void SetType(ImageType&& value) { m_typeHasBeenSet = true; m_type = std::move(value); } /** *

Specifies whether this image produces an AMI or a container image.

*/ inline ImageVersion& WithType(const ImageType& value) { SetType(value); return *this;} /** *

Specifies whether this image produces an AMI or a container image.

*/ inline ImageVersion& WithType(ImageType&& value) { SetType(std::move(value)); return *this;} /** *

Details for a specific version of an Image Builder image. This version * follows the semantic version syntax.

The semantic version has four * nodes: <major>.<minor>.<patch>/<build>. You can assign * values for the first three, and can filter on all of them.

* Assignment: For the first three nodes you can assign any positive integer * value, including zero, with an upper limit of 2^30-1, or 1073741823 for each * node. Image Builder automatically assigns the build number to the fourth * node.

Patterns: You can use any numeric pattern that adheres to * the assignment requirements for the nodes that you can assign. For example, you * might choose a software version pattern, such as 1.0.0, or a date, such as * 2021.01.01.

Filtering: With semantic versioning, you have the * flexibility to use wildcards (x) to specify the most recent versions or nodes * when selecting the base image or components for your recipe. When you use a * wildcard in any node, all nodes to the right of the first wildcard must also be * wildcards.

*/ inline const Aws::String& GetVersion() const{ return m_version; } /** *

Details for a specific version of an Image Builder image. This version * follows the semantic version syntax.

The semantic version has four * nodes: <major>.<minor>.<patch>/<build>. You can assign * values for the first three, and can filter on all of them.

* Assignment: For the first three nodes you can assign any positive integer * value, including zero, with an upper limit of 2^30-1, or 1073741823 for each * node. Image Builder automatically assigns the build number to the fourth * node.

Patterns: You can use any numeric pattern that adheres to * the assignment requirements for the nodes that you can assign. For example, you * might choose a software version pattern, such as 1.0.0, or a date, such as * 2021.01.01.

Filtering: With semantic versioning, you have the * flexibility to use wildcards (x) to specify the most recent versions or nodes * when selecting the base image or components for your recipe. When you use a * wildcard in any node, all nodes to the right of the first wildcard must also be * wildcards.

*/ inline bool VersionHasBeenSet() const { return m_versionHasBeenSet; } /** *

Details for a specific version of an Image Builder image. This version * follows the semantic version syntax.

The semantic version has four * nodes: <major>.<minor>.<patch>/<build>. You can assign * values for the first three, and can filter on all of them.

* Assignment: For the first three nodes you can assign any positive integer * value, including zero, with an upper limit of 2^30-1, or 1073741823 for each * node. Image Builder automatically assigns the build number to the fourth * node.

Patterns: You can use any numeric pattern that adheres to * the assignment requirements for the nodes that you can assign. For example, you * might choose a software version pattern, such as 1.0.0, or a date, such as * 2021.01.01.

Filtering: With semantic versioning, you have the * flexibility to use wildcards (x) to specify the most recent versions or nodes * when selecting the base image or components for your recipe. When you use a * wildcard in any node, all nodes to the right of the first wildcard must also be * wildcards.

*/ inline void SetVersion(const Aws::String& value) { m_versionHasBeenSet = true; m_version = value; } /** *

Details for a specific version of an Image Builder image. This version * follows the semantic version syntax.

The semantic version has four * nodes: <major>.<minor>.<patch>/<build>. You can assign * values for the first three, and can filter on all of them.

* Assignment: For the first three nodes you can assign any positive integer * value, including zero, with an upper limit of 2^30-1, or 1073741823 for each * node. Image Builder automatically assigns the build number to the fourth * node.

Patterns: You can use any numeric pattern that adheres to * the assignment requirements for the nodes that you can assign. For example, you * might choose a software version pattern, such as 1.0.0, or a date, such as * 2021.01.01.

Filtering: With semantic versioning, you have the * flexibility to use wildcards (x) to specify the most recent versions or nodes * when selecting the base image or components for your recipe. When you use a * wildcard in any node, all nodes to the right of the first wildcard must also be * wildcards.

*/ inline void SetVersion(Aws::String&& value) { m_versionHasBeenSet = true; m_version = std::move(value); } /** *

Details for a specific version of an Image Builder image. This version * follows the semantic version syntax.

The semantic version has four * nodes: <major>.<minor>.<patch>/<build>. You can assign * values for the first three, and can filter on all of them.

* Assignment: For the first three nodes you can assign any positive integer * value, including zero, with an upper limit of 2^30-1, or 1073741823 for each * node. Image Builder automatically assigns the build number to the fourth * node.

Patterns: You can use any numeric pattern that adheres to * the assignment requirements for the nodes that you can assign. For example, you * might choose a software version pattern, such as 1.0.0, or a date, such as * 2021.01.01.

Filtering: With semantic versioning, you have the * flexibility to use wildcards (x) to specify the most recent versions or nodes * when selecting the base image or components for your recipe. When you use a * wildcard in any node, all nodes to the right of the first wildcard must also be * wildcards.

*/ inline void SetVersion(const char* value) { m_versionHasBeenSet = true; m_version.assign(value); } /** *

Details for a specific version of an Image Builder image. This version * follows the semantic version syntax.

The semantic version has four * nodes: <major>.<minor>.<patch>/<build>. You can assign * values for the first three, and can filter on all of them.

* Assignment: For the first three nodes you can assign any positive integer * value, including zero, with an upper limit of 2^30-1, or 1073741823 for each * node. Image Builder automatically assigns the build number to the fourth * node.

Patterns: You can use any numeric pattern that adheres to * the assignment requirements for the nodes that you can assign. For example, you * might choose a software version pattern, such as 1.0.0, or a date, such as * 2021.01.01.

Filtering: With semantic versioning, you have the * flexibility to use wildcards (x) to specify the most recent versions or nodes * when selecting the base image or components for your recipe. When you use a * wildcard in any node, all nodes to the right of the first wildcard must also be * wildcards.

*/ inline ImageVersion& WithVersion(const Aws::String& value) { SetVersion(value); return *this;} /** *

Details for a specific version of an Image Builder image. This version * follows the semantic version syntax.

The semantic version has four * nodes: <major>.<minor>.<patch>/<build>. You can assign * values for the first three, and can filter on all of them.

* Assignment: For the first three nodes you can assign any positive integer * value, including zero, with an upper limit of 2^30-1, or 1073741823 for each * node. Image Builder automatically assigns the build number to the fourth * node.

Patterns: You can use any numeric pattern that adheres to * the assignment requirements for the nodes that you can assign. For example, you * might choose a software version pattern, such as 1.0.0, or a date, such as * 2021.01.01.

Filtering: With semantic versioning, you have the * flexibility to use wildcards (x) to specify the most recent versions or nodes * when selecting the base image or components for your recipe. When you use a * wildcard in any node, all nodes to the right of the first wildcard must also be * wildcards.

*/ inline ImageVersion& WithVersion(Aws::String&& value) { SetVersion(std::move(value)); return *this;} /** *

Details for a specific version of an Image Builder image. This version * follows the semantic version syntax.

The semantic version has four * nodes: <major>.<minor>.<patch>/<build>. You can assign * values for the first three, and can filter on all of them.

* Assignment: For the first three nodes you can assign any positive integer * value, including zero, with an upper limit of 2^30-1, or 1073741823 for each * node. Image Builder automatically assigns the build number to the fourth * node.

Patterns: You can use any numeric pattern that adheres to * the assignment requirements for the nodes that you can assign. For example, you * might choose a software version pattern, such as 1.0.0, or a date, such as * 2021.01.01.

Filtering: With semantic versioning, you have the * flexibility to use wildcards (x) to specify the most recent versions or nodes * when selecting the base image or components for your recipe. When you use a * wildcard in any node, all nodes to the right of the first wildcard must also be * wildcards.

*/ inline ImageVersion& WithVersion(const char* value) { SetVersion(value); return *this;} /** *

The operating system platform of the image version, for example "Windows" or * "Linux".

*/ inline const Platform& GetPlatform() const{ return m_platform; } /** *

The operating system platform of the image version, for example "Windows" or * "Linux".

*/ inline bool PlatformHasBeenSet() const { return m_platformHasBeenSet; } /** *

The operating system platform of the image version, for example "Windows" or * "Linux".

*/ inline void SetPlatform(const Platform& value) { m_platformHasBeenSet = true; m_platform = value; } /** *

The operating system platform of the image version, for example "Windows" or * "Linux".

*/ inline void SetPlatform(Platform&& value) { m_platformHasBeenSet = true; m_platform = std::move(value); } /** *

The operating system platform of the image version, for example "Windows" or * "Linux".

*/ inline ImageVersion& WithPlatform(const Platform& value) { SetPlatform(value); return *this;} /** *

The operating system platform of the image version, for example "Windows" or * "Linux".

*/ inline ImageVersion& WithPlatform(Platform&& value) { SetPlatform(std::move(value)); return *this;} /** *

The operating system version of the Amazon EC2 build instance. For example, * Amazon Linux 2, Ubuntu 18, or Microsoft Windows Server 2019.

*/ inline const Aws::String& GetOsVersion() const{ return m_osVersion; } /** *

The operating system version of the Amazon EC2 build instance. For example, * Amazon Linux 2, Ubuntu 18, or Microsoft Windows Server 2019.

*/ inline bool OsVersionHasBeenSet() const { return m_osVersionHasBeenSet; } /** *

The operating system version of the Amazon EC2 build instance. For example, * Amazon Linux 2, Ubuntu 18, or Microsoft Windows Server 2019.

*/ inline void SetOsVersion(const Aws::String& value) { m_osVersionHasBeenSet = true; m_osVersion = value; } /** *

The operating system version of the Amazon EC2 build instance. For example, * Amazon Linux 2, Ubuntu 18, or Microsoft Windows Server 2019.

*/ inline void SetOsVersion(Aws::String&& value) { m_osVersionHasBeenSet = true; m_osVersion = std::move(value); } /** *

The operating system version of the Amazon EC2 build instance. For example, * Amazon Linux 2, Ubuntu 18, or Microsoft Windows Server 2019.

*/ inline void SetOsVersion(const char* value) { m_osVersionHasBeenSet = true; m_osVersion.assign(value); } /** *

The operating system version of the Amazon EC2 build instance. For example, * Amazon Linux 2, Ubuntu 18, or Microsoft Windows Server 2019.

*/ inline ImageVersion& WithOsVersion(const Aws::String& value) { SetOsVersion(value); return *this;} /** *

The operating system version of the Amazon EC2 build instance. For example, * Amazon Linux 2, Ubuntu 18, or Microsoft Windows Server 2019.

*/ inline ImageVersion& WithOsVersion(Aws::String&& value) { SetOsVersion(std::move(value)); return *this;} /** *

The operating system version of the Amazon EC2 build instance. For example, * Amazon Linux 2, Ubuntu 18, or Microsoft Windows Server 2019.

*/ inline ImageVersion& WithOsVersion(const char* value) { SetOsVersion(value); return *this;} /** *

The owner of the image version.

*/ inline const Aws::String& GetOwner() const{ return m_owner; } /** *

The owner of the image version.

*/ inline bool OwnerHasBeenSet() const { return m_ownerHasBeenSet; } /** *

The owner of the image version.

*/ inline void SetOwner(const Aws::String& value) { m_ownerHasBeenSet = true; m_owner = value; } /** *

The owner of the image version.

*/ inline void SetOwner(Aws::String&& value) { m_ownerHasBeenSet = true; m_owner = std::move(value); } /** *

The owner of the image version.

*/ inline void SetOwner(const char* value) { m_ownerHasBeenSet = true; m_owner.assign(value); } /** *

The owner of the image version.

*/ inline ImageVersion& WithOwner(const Aws::String& value) { SetOwner(value); return *this;} /** *

The owner of the image version.

*/ inline ImageVersion& WithOwner(Aws::String&& value) { SetOwner(std::move(value)); return *this;} /** *

The owner of the image version.

*/ inline ImageVersion& WithOwner(const char* value) { SetOwner(value); return *this;} /** *

The date on which this specific version of the Image Builder image was * created.

*/ inline const Aws::String& GetDateCreated() const{ return m_dateCreated; } /** *

The date on which this specific version of the Image Builder image was * created.

*/ inline bool DateCreatedHasBeenSet() const { return m_dateCreatedHasBeenSet; } /** *

The date on which this specific version of the Image Builder image was * created.

*/ inline void SetDateCreated(const Aws::String& value) { m_dateCreatedHasBeenSet = true; m_dateCreated = value; } /** *

The date on which this specific version of the Image Builder image was * created.

*/ inline void SetDateCreated(Aws::String&& value) { m_dateCreatedHasBeenSet = true; m_dateCreated = std::move(value); } /** *

The date on which this specific version of the Image Builder image was * created.

*/ inline void SetDateCreated(const char* value) { m_dateCreatedHasBeenSet = true; m_dateCreated.assign(value); } /** *

The date on which this specific version of the Image Builder image was * created.

*/ inline ImageVersion& WithDateCreated(const Aws::String& value) { SetDateCreated(value); return *this;} /** *

The date on which this specific version of the Image Builder image was * created.

*/ inline ImageVersion& WithDateCreated(Aws::String&& value) { SetDateCreated(std::move(value)); return *this;} /** *

The date on which this specific version of the Image Builder image was * created.

*/ inline ImageVersion& WithDateCreated(const char* value) { SetDateCreated(value); return *this;} /** *

Indicates the type of build that created this image. The build can be * initiated in the following ways:

  • USER_INITIATED – A * manual pipeline build request.

  • SCHEDULED – A pipeline * build initiated by a cron expression in the Image Builder pipeline, or from * EventBridge.

  • IMPORT – A VM import created the image to * use as the base image for the recipe.

*/ inline const BuildType& GetBuildType() const{ return m_buildType; } /** *

Indicates the type of build that created this image. The build can be * initiated in the following ways:

  • USER_INITIATED – A * manual pipeline build request.

  • SCHEDULED – A pipeline * build initiated by a cron expression in the Image Builder pipeline, or from * EventBridge.

  • IMPORT – A VM import created the image to * use as the base image for the recipe.

*/ inline bool BuildTypeHasBeenSet() const { return m_buildTypeHasBeenSet; } /** *

Indicates the type of build that created this image. The build can be * initiated in the following ways:

  • USER_INITIATED – A * manual pipeline build request.

  • SCHEDULED – A pipeline * build initiated by a cron expression in the Image Builder pipeline, or from * EventBridge.

  • IMPORT – A VM import created the image to * use as the base image for the recipe.

*/ inline void SetBuildType(const BuildType& value) { m_buildTypeHasBeenSet = true; m_buildType = value; } /** *

Indicates the type of build that created this image. The build can be * initiated in the following ways:

  • USER_INITIATED – A * manual pipeline build request.

  • SCHEDULED – A pipeline * build initiated by a cron expression in the Image Builder pipeline, or from * EventBridge.

  • IMPORT – A VM import created the image to * use as the base image for the recipe.

*/ inline void SetBuildType(BuildType&& value) { m_buildTypeHasBeenSet = true; m_buildType = std::move(value); } /** *

Indicates the type of build that created this image. The build can be * initiated in the following ways:

  • USER_INITIATED – A * manual pipeline build request.

  • SCHEDULED – A pipeline * build initiated by a cron expression in the Image Builder pipeline, or from * EventBridge.

  • IMPORT – A VM import created the image to * use as the base image for the recipe.

*/ inline ImageVersion& WithBuildType(const BuildType& value) { SetBuildType(value); return *this;} /** *

Indicates the type of build that created this image. The build can be * initiated in the following ways:

  • USER_INITIATED – A * manual pipeline build request.

  • SCHEDULED – A pipeline * build initiated by a cron expression in the Image Builder pipeline, or from * EventBridge.

  • IMPORT – A VM import created the image to * use as the base image for the recipe.

*/ inline ImageVersion& WithBuildType(BuildType&& value) { SetBuildType(std::move(value)); return *this;} /** *

The origin of the base image that Image Builder used to build this image.

*/ inline const ImageSource& GetImageSource() const{ return m_imageSource; } /** *

The origin of the base image that Image Builder used to build this image.

*/ inline bool ImageSourceHasBeenSet() const { return m_imageSourceHasBeenSet; } /** *

The origin of the base image that Image Builder used to build this image.

*/ inline void SetImageSource(const ImageSource& value) { m_imageSourceHasBeenSet = true; m_imageSource = value; } /** *

The origin of the base image that Image Builder used to build this image.

*/ inline void SetImageSource(ImageSource&& value) { m_imageSourceHasBeenSet = true; m_imageSource = std::move(value); } /** *

The origin of the base image that Image Builder used to build this image.

*/ inline ImageVersion& WithImageSource(const ImageSource& value) { SetImageSource(value); return *this;} /** *

The origin of the base image that Image Builder used to build this image.

*/ inline ImageVersion& WithImageSource(ImageSource&& value) { SetImageSource(std::move(value)); return *this;} private: Aws::String m_arn; bool m_arnHasBeenSet = false; Aws::String m_name; bool m_nameHasBeenSet = false; ImageType m_type; bool m_typeHasBeenSet = false; Aws::String m_version; bool m_versionHasBeenSet = false; Platform m_platform; bool m_platformHasBeenSet = false; Aws::String m_osVersion; bool m_osVersionHasBeenSet = false; Aws::String m_owner; bool m_ownerHasBeenSet = false; Aws::String m_dateCreated; bool m_dateCreatedHasBeenSet = false; BuildType m_buildType; bool m_buildTypeHasBeenSet = false; ImageSource m_imageSource; bool m_imageSourceHasBeenSet = false; }; } // namespace Model } // namespace imagebuilder } // namespace Aws