/** * 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 Batch { namespace Model { /** */ class AWS_BATCH_API CreateComputeEnvironmentRequest : public BatchRequest { public: CreateComputeEnvironmentRequest(); // Service request name is the Operation name which will send this request out, // each operation should has unique request name, so that we can get operation's name from this request. // Note: this is not true for response, multiple operations may have the same response name, // so we can not get operation's name from response. inline virtual const char* GetServiceRequestName() const override { return "CreateComputeEnvironment"; } Aws::String SerializePayload() const override; /** *

The name for your compute environment. Up to 128 letters (uppercase and * lowercase), numbers, hyphens, and underscores are allowed.

*/ inline const Aws::String& GetComputeEnvironmentName() const{ return m_computeEnvironmentName; } /** *

The name for your compute environment. Up to 128 letters (uppercase and * lowercase), numbers, hyphens, and underscores are allowed.

*/ inline bool ComputeEnvironmentNameHasBeenSet() const { return m_computeEnvironmentNameHasBeenSet; } /** *

The name for your compute environment. Up to 128 letters (uppercase and * lowercase), numbers, hyphens, and underscores are allowed.

*/ inline void SetComputeEnvironmentName(const Aws::String& value) { m_computeEnvironmentNameHasBeenSet = true; m_computeEnvironmentName = value; } /** *

The name for your compute environment. Up to 128 letters (uppercase and * lowercase), numbers, hyphens, and underscores are allowed.

*/ inline void SetComputeEnvironmentName(Aws::String&& value) { m_computeEnvironmentNameHasBeenSet = true; m_computeEnvironmentName = std::move(value); } /** *

The name for your compute environment. Up to 128 letters (uppercase and * lowercase), numbers, hyphens, and underscores are allowed.

*/ inline void SetComputeEnvironmentName(const char* value) { m_computeEnvironmentNameHasBeenSet = true; m_computeEnvironmentName.assign(value); } /** *

The name for your compute environment. Up to 128 letters (uppercase and * lowercase), numbers, hyphens, and underscores are allowed.

*/ inline CreateComputeEnvironmentRequest& WithComputeEnvironmentName(const Aws::String& value) { SetComputeEnvironmentName(value); return *this;} /** *

The name for your compute environment. Up to 128 letters (uppercase and * lowercase), numbers, hyphens, and underscores are allowed.

*/ inline CreateComputeEnvironmentRequest& WithComputeEnvironmentName(Aws::String&& value) { SetComputeEnvironmentName(std::move(value)); return *this;} /** *

The name for your compute environment. Up to 128 letters (uppercase and * lowercase), numbers, hyphens, and underscores are allowed.

*/ inline CreateComputeEnvironmentRequest& WithComputeEnvironmentName(const char* value) { SetComputeEnvironmentName(value); return *this;} /** *

The type of the compute environment. For more information, see Compute * Environments in the AWS Batch User Guide.

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

The type of the compute environment. For more information, see Compute * Environments in the AWS Batch User Guide.

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

The type of the compute environment. For more information, see Compute * Environments in the AWS Batch User Guide.

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

The type of the compute environment. For more information, see Compute * Environments in the AWS Batch User Guide.

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

The type of the compute environment. For more information, see Compute * Environments in the AWS Batch User Guide.

*/ inline CreateComputeEnvironmentRequest& WithType(const CEType& value) { SetType(value); return *this;} /** *

The type of the compute environment. For more information, see Compute * Environments in the AWS Batch User Guide.

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

The state of the compute environment. If the state is ENABLED, * then the compute environment accepts jobs from a queue and can scale out * automatically based on queues.

*/ inline const CEState& GetState() const{ return m_state; } /** *

The state of the compute environment. If the state is ENABLED, * then the compute environment accepts jobs from a queue and can scale out * automatically based on queues.

*/ inline bool StateHasBeenSet() const { return m_stateHasBeenSet; } /** *

The state of the compute environment. If the state is ENABLED, * then the compute environment accepts jobs from a queue and can scale out * automatically based on queues.

*/ inline void SetState(const CEState& value) { m_stateHasBeenSet = true; m_state = value; } /** *

The state of the compute environment. If the state is ENABLED, * then the compute environment accepts jobs from a queue and can scale out * automatically based on queues.

*/ inline void SetState(CEState&& value) { m_stateHasBeenSet = true; m_state = std::move(value); } /** *

The state of the compute environment. If the state is ENABLED, * then the compute environment accepts jobs from a queue and can scale out * automatically based on queues.

*/ inline CreateComputeEnvironmentRequest& WithState(const CEState& value) { SetState(value); return *this;} /** *

The state of the compute environment. If the state is ENABLED, * then the compute environment accepts jobs from a queue and can scale out * automatically based on queues.

*/ inline CreateComputeEnvironmentRequest& WithState(CEState&& value) { SetState(std::move(value)); return *this;} /** *

Details of the compute resources managed by the compute environment. This * parameter is required for managed compute environments. For more information, * see Compute * Environments in the AWS Batch User Guide.

*/ inline const ComputeResource& GetComputeResources() const{ return m_computeResources; } /** *

Details of the compute resources managed by the compute environment. This * parameter is required for managed compute environments. For more information, * see Compute * Environments in the AWS Batch User Guide.

*/ inline bool ComputeResourcesHasBeenSet() const { return m_computeResourcesHasBeenSet; } /** *

Details of the compute resources managed by the compute environment. This * parameter is required for managed compute environments. For more information, * see Compute * Environments in the AWS Batch User Guide.

*/ inline void SetComputeResources(const ComputeResource& value) { m_computeResourcesHasBeenSet = true; m_computeResources = value; } /** *

Details of the compute resources managed by the compute environment. This * parameter is required for managed compute environments. For more information, * see Compute * Environments in the AWS Batch User Guide.

*/ inline void SetComputeResources(ComputeResource&& value) { m_computeResourcesHasBeenSet = true; m_computeResources = std::move(value); } /** *

Details of the compute resources managed by the compute environment. This * parameter is required for managed compute environments. For more information, * see Compute * Environments in the AWS Batch User Guide.

*/ inline CreateComputeEnvironmentRequest& WithComputeResources(const ComputeResource& value) { SetComputeResources(value); return *this;} /** *

Details of the compute resources managed by the compute environment. This * parameter is required for managed compute environments. For more information, * see Compute * Environments in the AWS Batch User Guide.

*/ inline CreateComputeEnvironmentRequest& WithComputeResources(ComputeResource&& value) { SetComputeResources(std::move(value)); return *this;} /** *

The full Amazon Resource Name (ARN) of the IAM role that allows AWS Batch to * make calls to other AWS services on your behalf.

If your specified role * has a path other than /, then you must either specify the full role * ARN (this is recommended) or prefix the role name with the path.

*

Depending on how you created your AWS Batch service role, its ARN may contain * the service-role path prefix. When you only specify the name of the * service role, AWS Batch assumes that your ARN does not use the * service-role path prefix. Because of this, we recommend that you * specify the full ARN of your service role when you create compute * environments.

*/ inline const Aws::String& GetServiceRole() const{ return m_serviceRole; } /** *

The full Amazon Resource Name (ARN) of the IAM role that allows AWS Batch to * make calls to other AWS services on your behalf.

If your specified role * has a path other than /, then you must either specify the full role * ARN (this is recommended) or prefix the role name with the path.

*

Depending on how you created your AWS Batch service role, its ARN may contain * the service-role path prefix. When you only specify the name of the * service role, AWS Batch assumes that your ARN does not use the * service-role path prefix. Because of this, we recommend that you * specify the full ARN of your service role when you create compute * environments.

*/ inline bool ServiceRoleHasBeenSet() const { return m_serviceRoleHasBeenSet; } /** *

The full Amazon Resource Name (ARN) of the IAM role that allows AWS Batch to * make calls to other AWS services on your behalf.

If your specified role * has a path other than /, then you must either specify the full role * ARN (this is recommended) or prefix the role name with the path.

*

Depending on how you created your AWS Batch service role, its ARN may contain * the service-role path prefix. When you only specify the name of the * service role, AWS Batch assumes that your ARN does not use the * service-role path prefix. Because of this, we recommend that you * specify the full ARN of your service role when you create compute * environments.

*/ inline void SetServiceRole(const Aws::String& value) { m_serviceRoleHasBeenSet = true; m_serviceRole = value; } /** *

The full Amazon Resource Name (ARN) of the IAM role that allows AWS Batch to * make calls to other AWS services on your behalf.

If your specified role * has a path other than /, then you must either specify the full role * ARN (this is recommended) or prefix the role name with the path.

*

Depending on how you created your AWS Batch service role, its ARN may contain * the service-role path prefix. When you only specify the name of the * service role, AWS Batch assumes that your ARN does not use the * service-role path prefix. Because of this, we recommend that you * specify the full ARN of your service role when you create compute * environments.

*/ inline void SetServiceRole(Aws::String&& value) { m_serviceRoleHasBeenSet = true; m_serviceRole = std::move(value); } /** *

The full Amazon Resource Name (ARN) of the IAM role that allows AWS Batch to * make calls to other AWS services on your behalf.

If your specified role * has a path other than /, then you must either specify the full role * ARN (this is recommended) or prefix the role name with the path.

*

Depending on how you created your AWS Batch service role, its ARN may contain * the service-role path prefix. When you only specify the name of the * service role, AWS Batch assumes that your ARN does not use the * service-role path prefix. Because of this, we recommend that you * specify the full ARN of your service role when you create compute * environments.

*/ inline void SetServiceRole(const char* value) { m_serviceRoleHasBeenSet = true; m_serviceRole.assign(value); } /** *

The full Amazon Resource Name (ARN) of the IAM role that allows AWS Batch to * make calls to other AWS services on your behalf.

If your specified role * has a path other than /, then you must either specify the full role * ARN (this is recommended) or prefix the role name with the path.

*

Depending on how you created your AWS Batch service role, its ARN may contain * the service-role path prefix. When you only specify the name of the * service role, AWS Batch assumes that your ARN does not use the * service-role path prefix. Because of this, we recommend that you * specify the full ARN of your service role when you create compute * environments.

*/ inline CreateComputeEnvironmentRequest& WithServiceRole(const Aws::String& value) { SetServiceRole(value); return *this;} /** *

The full Amazon Resource Name (ARN) of the IAM role that allows AWS Batch to * make calls to other AWS services on your behalf.

If your specified role * has a path other than /, then you must either specify the full role * ARN (this is recommended) or prefix the role name with the path.

*

Depending on how you created your AWS Batch service role, its ARN may contain * the service-role path prefix. When you only specify the name of the * service role, AWS Batch assumes that your ARN does not use the * service-role path prefix. Because of this, we recommend that you * specify the full ARN of your service role when you create compute * environments.

*/ inline CreateComputeEnvironmentRequest& WithServiceRole(Aws::String&& value) { SetServiceRole(std::move(value)); return *this;} /** *

The full Amazon Resource Name (ARN) of the IAM role that allows AWS Batch to * make calls to other AWS services on your behalf.

If your specified role * has a path other than /, then you must either specify the full role * ARN (this is recommended) or prefix the role name with the path.

*

Depending on how you created your AWS Batch service role, its ARN may contain * the service-role path prefix. When you only specify the name of the * service role, AWS Batch assumes that your ARN does not use the * service-role path prefix. Because of this, we recommend that you * specify the full ARN of your service role when you create compute * environments.

*/ inline CreateComputeEnvironmentRequest& WithServiceRole(const char* value) { SetServiceRole(value); return *this;} private: Aws::String m_computeEnvironmentName; bool m_computeEnvironmentNameHasBeenSet; CEType m_type; bool m_typeHasBeenSet; CEState m_state; bool m_stateHasBeenSet; ComputeResource m_computeResources; bool m_computeResourcesHasBeenSet; Aws::String m_serviceRole; bool m_serviceRoleHasBeenSet; }; } // namespace Model } // namespace Batch } // namespace Aws