/** * 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 ECS { namespace Model { /** */ class DescribeServicesRequest : public ECSRequest { public: AWS_ECS_API DescribeServicesRequest(); // 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 "DescribeServices"; } AWS_ECS_API Aws::String SerializePayload() const override; AWS_ECS_API Aws::Http::HeaderValueCollection GetRequestSpecificHeaders() const override; /** *

The short name or full Amazon Resource Name (ARN)the cluster that hosts the * service to describe. If you do not specify a cluster, the default cluster is * assumed. This parameter is required if the service or services you are * describing were launched in any cluster other than the default cluster.

*/ inline const Aws::String& GetCluster() const{ return m_cluster; } /** *

The short name or full Amazon Resource Name (ARN)the cluster that hosts the * service to describe. If you do not specify a cluster, the default cluster is * assumed. This parameter is required if the service or services you are * describing were launched in any cluster other than the default cluster.

*/ inline bool ClusterHasBeenSet() const { return m_clusterHasBeenSet; } /** *

The short name or full Amazon Resource Name (ARN)the cluster that hosts the * service to describe. If you do not specify a cluster, the default cluster is * assumed. This parameter is required if the service or services you are * describing were launched in any cluster other than the default cluster.

*/ inline void SetCluster(const Aws::String& value) { m_clusterHasBeenSet = true; m_cluster = value; } /** *

The short name or full Amazon Resource Name (ARN)the cluster that hosts the * service to describe. If you do not specify a cluster, the default cluster is * assumed. This parameter is required if the service or services you are * describing were launched in any cluster other than the default cluster.

*/ inline void SetCluster(Aws::String&& value) { m_clusterHasBeenSet = true; m_cluster = std::move(value); } /** *

The short name or full Amazon Resource Name (ARN)the cluster that hosts the * service to describe. If you do not specify a cluster, the default cluster is * assumed. This parameter is required if the service or services you are * describing were launched in any cluster other than the default cluster.

*/ inline void SetCluster(const char* value) { m_clusterHasBeenSet = true; m_cluster.assign(value); } /** *

The short name or full Amazon Resource Name (ARN)the cluster that hosts the * service to describe. If you do not specify a cluster, the default cluster is * assumed. This parameter is required if the service or services you are * describing were launched in any cluster other than the default cluster.

*/ inline DescribeServicesRequest& WithCluster(const Aws::String& value) { SetCluster(value); return *this;} /** *

The short name or full Amazon Resource Name (ARN)the cluster that hosts the * service to describe. If you do not specify a cluster, the default cluster is * assumed. This parameter is required if the service or services you are * describing were launched in any cluster other than the default cluster.

*/ inline DescribeServicesRequest& WithCluster(Aws::String&& value) { SetCluster(std::move(value)); return *this;} /** *

The short name or full Amazon Resource Name (ARN)the cluster that hosts the * service to describe. If you do not specify a cluster, the default cluster is * assumed. This parameter is required if the service or services you are * describing were launched in any cluster other than the default cluster.

*/ inline DescribeServicesRequest& WithCluster(const char* value) { SetCluster(value); return *this;} /** *

A list of services to describe. You may specify up to 10 services to describe * in a single operation.

*/ inline const Aws::Vector& GetServices() const{ return m_services; } /** *

A list of services to describe. You may specify up to 10 services to describe * in a single operation.

*/ inline bool ServicesHasBeenSet() const { return m_servicesHasBeenSet; } /** *

A list of services to describe. You may specify up to 10 services to describe * in a single operation.

*/ inline void SetServices(const Aws::Vector& value) { m_servicesHasBeenSet = true; m_services = value; } /** *

A list of services to describe. You may specify up to 10 services to describe * in a single operation.

*/ inline void SetServices(Aws::Vector&& value) { m_servicesHasBeenSet = true; m_services = std::move(value); } /** *

A list of services to describe. You may specify up to 10 services to describe * in a single operation.

*/ inline DescribeServicesRequest& WithServices(const Aws::Vector& value) { SetServices(value); return *this;} /** *

A list of services to describe. You may specify up to 10 services to describe * in a single operation.

*/ inline DescribeServicesRequest& WithServices(Aws::Vector&& value) { SetServices(std::move(value)); return *this;} /** *

A list of services to describe. You may specify up to 10 services to describe * in a single operation.

*/ inline DescribeServicesRequest& AddServices(const Aws::String& value) { m_servicesHasBeenSet = true; m_services.push_back(value); return *this; } /** *

A list of services to describe. You may specify up to 10 services to describe * in a single operation.

*/ inline DescribeServicesRequest& AddServices(Aws::String&& value) { m_servicesHasBeenSet = true; m_services.push_back(std::move(value)); return *this; } /** *

A list of services to describe. You may specify up to 10 services to describe * in a single operation.

*/ inline DescribeServicesRequest& AddServices(const char* value) { m_servicesHasBeenSet = true; m_services.push_back(value); return *this; } /** *

Determines whether you want to see the resource tags for the service. If * TAGS is specified, the tags are included in the response. If this * field is omitted, tags aren't included in the response.

*/ inline const Aws::Vector& GetInclude() const{ return m_include; } /** *

Determines whether you want to see the resource tags for the service. If * TAGS is specified, the tags are included in the response. If this * field is omitted, tags aren't included in the response.

*/ inline bool IncludeHasBeenSet() const { return m_includeHasBeenSet; } /** *

Determines whether you want to see the resource tags for the service. If * TAGS is specified, the tags are included in the response. If this * field is omitted, tags aren't included in the response.

*/ inline void SetInclude(const Aws::Vector& value) { m_includeHasBeenSet = true; m_include = value; } /** *

Determines whether you want to see the resource tags for the service. If * TAGS is specified, the tags are included in the response. If this * field is omitted, tags aren't included in the response.

*/ inline void SetInclude(Aws::Vector&& value) { m_includeHasBeenSet = true; m_include = std::move(value); } /** *

Determines whether you want to see the resource tags for the service. If * TAGS is specified, the tags are included in the response. If this * field is omitted, tags aren't included in the response.

*/ inline DescribeServicesRequest& WithInclude(const Aws::Vector& value) { SetInclude(value); return *this;} /** *

Determines whether you want to see the resource tags for the service. If * TAGS is specified, the tags are included in the response. If this * field is omitted, tags aren't included in the response.

*/ inline DescribeServicesRequest& WithInclude(Aws::Vector&& value) { SetInclude(std::move(value)); return *this;} /** *

Determines whether you want to see the resource tags for the service. If * TAGS is specified, the tags are included in the response. If this * field is omitted, tags aren't included in the response.

*/ inline DescribeServicesRequest& AddInclude(const ServiceField& value) { m_includeHasBeenSet = true; m_include.push_back(value); return *this; } /** *

Determines whether you want to see the resource tags for the service. If * TAGS is specified, the tags are included in the response. If this * field is omitted, tags aren't included in the response.

*/ inline DescribeServicesRequest& AddInclude(ServiceField&& value) { m_includeHasBeenSet = true; m_include.push_back(std::move(value)); return *this; } private: Aws::String m_cluster; bool m_clusterHasBeenSet = false; Aws::Vector m_services; bool m_servicesHasBeenSet = false; Aws::Vector m_include; bool m_includeHasBeenSet = false; }; } // namespace Model } // namespace ECS } // namespace Aws