/**
* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
* SPDX-License-Identifier: Apache-2.0.
*/
#pragma once
#include The defining characteristics of a specific version of an Amazon Web Services
* TOE component.See Also:
AWS
* API Reference
The Amazon Resource Name (ARN) of the component.
Semantic * versioning is included in each object's Amazon Resource Name (ARN), at the level * that applies to that object as follows:
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.
Version ARNs have only the first three nodes: * <major>.<minor>.<patch>
Build version ARNs * have all four nodes, and point to a specific build for a specific version of an * object.
The Amazon Resource Name (ARN) of the component.
Semantic * versioning is included in each object's Amazon Resource Name (ARN), at the level * that applies to that object as follows:
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.
Version ARNs have only the first three nodes: * <major>.<minor>.<patch>
Build version ARNs * have all four nodes, and point to a specific build for a specific version of an * object.
The Amazon Resource Name (ARN) of the component.
Semantic * versioning is included in each object's Amazon Resource Name (ARN), at the level * that applies to that object as follows:
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.
Version ARNs have only the first three nodes: * <major>.<minor>.<patch>
Build version ARNs * have all four nodes, and point to a specific build for a specific version of an * object.
The Amazon Resource Name (ARN) of the component.
Semantic * versioning is included in each object's Amazon Resource Name (ARN), at the level * that applies to that object as follows:
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.
Version ARNs have only the first three nodes: * <major>.<minor>.<patch>
Build version ARNs * have all four nodes, and point to a specific build for a specific version of an * object.
The Amazon Resource Name (ARN) of the component.
Semantic * versioning is included in each object's Amazon Resource Name (ARN), at the level * that applies to that object as follows:
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.
Version ARNs have only the first three nodes: * <major>.<minor>.<patch>
Build version ARNs * have all four nodes, and point to a specific build for a specific version of an * object.
The Amazon Resource Name (ARN) of the component.
Semantic * versioning is included in each object's Amazon Resource Name (ARN), at the level * that applies to that object as follows:
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.
Version ARNs have only the first three nodes: * <major>.<minor>.<patch>
Build version ARNs * have all four nodes, and point to a specific build for a specific version of an * object.
The Amazon Resource Name (ARN) of the component.
Semantic * versioning is included in each object's Amazon Resource Name (ARN), at the level * that applies to that object as follows:
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.
Version ARNs have only the first three nodes: * <major>.<minor>.<patch>
Build version ARNs * have all four nodes, and point to a specific build for a specific version of an * object.
The Amazon Resource Name (ARN) of the component.
Semantic * versioning is included in each object's Amazon Resource Name (ARN), at the level * that applies to that object as follows:
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.
Version ARNs have only the first three nodes: * <major>.<minor>.<patch>
Build version ARNs * have all four nodes, and point to a specific build for a specific version of an * object.
The name of the component.
*/ inline const Aws::String& GetName() const{ return m_name; } /** *The name of the component.
*/ inline bool NameHasBeenSet() const { return m_nameHasBeenSet; } /** *The name of the component.
*/ inline void SetName(const Aws::String& value) { m_nameHasBeenSet = true; m_name = value; } /** *The name of the component.
*/ inline void SetName(Aws::String&& value) { m_nameHasBeenSet = true; m_name = std::move(value); } /** *The name of the component.
*/ inline void SetName(const char* value) { m_nameHasBeenSet = true; m_name.assign(value); } /** *The name of the component.
*/ inline ComponentVersion& WithName(const Aws::String& value) { SetName(value); return *this;} /** *The name of the component.
*/ inline ComponentVersion& WithName(Aws::String&& value) { SetName(std::move(value)); return *this;} /** *The name of the component.
*/ inline ComponentVersion& WithName(const char* value) { SetName(value); return *this;} /** *The semantic version of the component.
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; } /** *The semantic version of the component.
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; } /** *The semantic version of the component.
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; } /** *The semantic version of the component.
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); } /** *The semantic version of the component.
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); } /** *The semantic version of the component.
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 ComponentVersion& WithVersion(const Aws::String& value) { SetVersion(value); return *this;} /** *The semantic version of the component.
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 ComponentVersion& WithVersion(Aws::String&& value) { SetVersion(std::move(value)); return *this;} /** *The semantic version of the component.
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 ComponentVersion& WithVersion(const char* value) { SetVersion(value); return *this;} /** *The description of the component.
*/ inline const Aws::String& GetDescription() const{ return m_description; } /** *The description of the component.
*/ inline bool DescriptionHasBeenSet() const { return m_descriptionHasBeenSet; } /** *The description of the component.
*/ inline void SetDescription(const Aws::String& value) { m_descriptionHasBeenSet = true; m_description = value; } /** *The description of the component.
*/ inline void SetDescription(Aws::String&& value) { m_descriptionHasBeenSet = true; m_description = std::move(value); } /** *The description of the component.
*/ inline void SetDescription(const char* value) { m_descriptionHasBeenSet = true; m_description.assign(value); } /** *The description of the component.
*/ inline ComponentVersion& WithDescription(const Aws::String& value) { SetDescription(value); return *this;} /** *The description of the component.
*/ inline ComponentVersion& WithDescription(Aws::String&& value) { SetDescription(std::move(value)); return *this;} /** *The description of the component.
*/ inline ComponentVersion& WithDescription(const char* value) { SetDescription(value); return *this;} /** *The platform of the component.
*/ inline const Platform& GetPlatform() const{ return m_platform; } /** *The platform of the component.
*/ inline bool PlatformHasBeenSet() const { return m_platformHasBeenSet; } /** *The platform of the component.
*/ inline void SetPlatform(const Platform& value) { m_platformHasBeenSet = true; m_platform = value; } /** *The platform of the component.
*/ inline void SetPlatform(Platform&& value) { m_platformHasBeenSet = true; m_platform = std::move(value); } /** *The platform of the component.
*/ inline ComponentVersion& WithPlatform(const Platform& value) { SetPlatform(value); return *this;} /** *The platform of the component.
*/ inline ComponentVersion& WithPlatform(Platform&& value) { SetPlatform(std::move(value)); return *this;} /** *he operating system (OS) version supported by the component. If the OS * information is available, a prefix match is performed against the base image OS * version during image recipe creation.
*/ inline const Aws::Vectorhe operating system (OS) version supported by the component. If the OS * information is available, a prefix match is performed against the base image OS * version during image recipe creation.
*/ inline bool SupportedOsVersionsHasBeenSet() const { return m_supportedOsVersionsHasBeenSet; } /** *he operating system (OS) version supported by the component. If the OS * information is available, a prefix match is performed against the base image OS * version during image recipe creation.
*/ inline void SetSupportedOsVersions(const Aws::Vectorhe operating system (OS) version supported by the component. If the OS * information is available, a prefix match is performed against the base image OS * version during image recipe creation.
*/ inline void SetSupportedOsVersions(Aws::Vectorhe operating system (OS) version supported by the component. If the OS * information is available, a prefix match is performed against the base image OS * version during image recipe creation.
*/ inline ComponentVersion& WithSupportedOsVersions(const Aws::Vectorhe operating system (OS) version supported by the component. If the OS * information is available, a prefix match is performed against the base image OS * version during image recipe creation.
*/ inline ComponentVersion& WithSupportedOsVersions(Aws::Vectorhe operating system (OS) version supported by the component. If the OS * information is available, a prefix match is performed against the base image OS * version during image recipe creation.
*/ inline ComponentVersion& AddSupportedOsVersions(const Aws::String& value) { m_supportedOsVersionsHasBeenSet = true; m_supportedOsVersions.push_back(value); return *this; } /** *he operating system (OS) version supported by the component. If the OS * information is available, a prefix match is performed against the base image OS * version during image recipe creation.
*/ inline ComponentVersion& AddSupportedOsVersions(Aws::String&& value) { m_supportedOsVersionsHasBeenSet = true; m_supportedOsVersions.push_back(std::move(value)); return *this; } /** *he operating system (OS) version supported by the component. If the OS * information is available, a prefix match is performed against the base image OS * version during image recipe creation.
*/ inline ComponentVersion& AddSupportedOsVersions(const char* value) { m_supportedOsVersionsHasBeenSet = true; m_supportedOsVersions.push_back(value); return *this; } /** *The type of the component denotes whether the component is used to build the * image or only to test it.
*/ inline const ComponentType& GetType() const{ return m_type; } /** *The type of the component denotes whether the component is used to build the * image or only to test it.
*/ inline bool TypeHasBeenSet() const { return m_typeHasBeenSet; } /** *The type of the component denotes whether the component is used to build the * image or only to test it.
*/ inline void SetType(const ComponentType& value) { m_typeHasBeenSet = true; m_type = value; } /** *The type of the component denotes whether the component is used to build the * image or only to test it.
*/ inline void SetType(ComponentType&& value) { m_typeHasBeenSet = true; m_type = std::move(value); } /** *The type of the component denotes whether the component is used to build the * image or only to test it.
*/ inline ComponentVersion& WithType(const ComponentType& value) { SetType(value); return *this;} /** *The type of the component denotes whether the component is used to build the * image or only to test it.
*/ inline ComponentVersion& WithType(ComponentType&& value) { SetType(std::move(value)); return *this;} /** *The owner of the component.
*/ inline const Aws::String& GetOwner() const{ return m_owner; } /** *The owner of the component.
*/ inline bool OwnerHasBeenSet() const { return m_ownerHasBeenSet; } /** *The owner of the component.
*/ inline void SetOwner(const Aws::String& value) { m_ownerHasBeenSet = true; m_owner = value; } /** *The owner of the component.
*/ inline void SetOwner(Aws::String&& value) { m_ownerHasBeenSet = true; m_owner = std::move(value); } /** *The owner of the component.
*/ inline void SetOwner(const char* value) { m_ownerHasBeenSet = true; m_owner.assign(value); } /** *The owner of the component.
*/ inline ComponentVersion& WithOwner(const Aws::String& value) { SetOwner(value); return *this;} /** *The owner of the component.
*/ inline ComponentVersion& WithOwner(Aws::String&& value) { SetOwner(std::move(value)); return *this;} /** *The owner of the component.
*/ inline ComponentVersion& WithOwner(const char* value) { SetOwner(value); return *this;} /** *The date that the component was created.
*/ inline const Aws::String& GetDateCreated() const{ return m_dateCreated; } /** *The date that the component was created.
*/ inline bool DateCreatedHasBeenSet() const { return m_dateCreatedHasBeenSet; } /** *The date that the component was created.
*/ inline void SetDateCreated(const Aws::String& value) { m_dateCreatedHasBeenSet = true; m_dateCreated = value; } /** *The date that the component was created.
*/ inline void SetDateCreated(Aws::String&& value) { m_dateCreatedHasBeenSet = true; m_dateCreated = std::move(value); } /** *The date that the component was created.
*/ inline void SetDateCreated(const char* value) { m_dateCreatedHasBeenSet = true; m_dateCreated.assign(value); } /** *The date that the component was created.
*/ inline ComponentVersion& WithDateCreated(const Aws::String& value) { SetDateCreated(value); return *this;} /** *The date that the component was created.
*/ inline ComponentVersion& WithDateCreated(Aws::String&& value) { SetDateCreated(std::move(value)); return *this;} /** *The date that the component was created.
*/ inline ComponentVersion& WithDateCreated(const char* value) { SetDateCreated(value); return *this;} private: Aws::String m_arn; bool m_arnHasBeenSet = false; Aws::String m_name; bool m_nameHasBeenSet = false; Aws::String m_version; bool m_versionHasBeenSet = false; Aws::String m_description; bool m_descriptionHasBeenSet = false; Platform m_platform; bool m_platformHasBeenSet = false; Aws::Vector