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

Request to list information about a resource.

See Also:

AWS * API Reference

*/ class GetResourceRequest : public APIGatewayRequest { public: AWS_APIGATEWAY_API GetResourceRequest(); // 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 "GetResource"; } AWS_APIGATEWAY_API Aws::String SerializePayload() const override; AWS_APIGATEWAY_API void AddQueryStringParameters(Aws::Http::URI& uri) const override; /** *

The string identifier of the associated RestApi.

*/ inline const Aws::String& GetRestApiId() const{ return m_restApiId; } /** *

The string identifier of the associated RestApi.

*/ inline bool RestApiIdHasBeenSet() const { return m_restApiIdHasBeenSet; } /** *

The string identifier of the associated RestApi.

*/ inline void SetRestApiId(const Aws::String& value) { m_restApiIdHasBeenSet = true; m_restApiId = value; } /** *

The string identifier of the associated RestApi.

*/ inline void SetRestApiId(Aws::String&& value) { m_restApiIdHasBeenSet = true; m_restApiId = std::move(value); } /** *

The string identifier of the associated RestApi.

*/ inline void SetRestApiId(const char* value) { m_restApiIdHasBeenSet = true; m_restApiId.assign(value); } /** *

The string identifier of the associated RestApi.

*/ inline GetResourceRequest& WithRestApiId(const Aws::String& value) { SetRestApiId(value); return *this;} /** *

The string identifier of the associated RestApi.

*/ inline GetResourceRequest& WithRestApiId(Aws::String&& value) { SetRestApiId(std::move(value)); return *this;} /** *

The string identifier of the associated RestApi.

*/ inline GetResourceRequest& WithRestApiId(const char* value) { SetRestApiId(value); return *this;} /** *

The identifier for the Resource resource.

*/ inline const Aws::String& GetResourceId() const{ return m_resourceId; } /** *

The identifier for the Resource resource.

*/ inline bool ResourceIdHasBeenSet() const { return m_resourceIdHasBeenSet; } /** *

The identifier for the Resource resource.

*/ inline void SetResourceId(const Aws::String& value) { m_resourceIdHasBeenSet = true; m_resourceId = value; } /** *

The identifier for the Resource resource.

*/ inline void SetResourceId(Aws::String&& value) { m_resourceIdHasBeenSet = true; m_resourceId = std::move(value); } /** *

The identifier for the Resource resource.

*/ inline void SetResourceId(const char* value) { m_resourceIdHasBeenSet = true; m_resourceId.assign(value); } /** *

The identifier for the Resource resource.

*/ inline GetResourceRequest& WithResourceId(const Aws::String& value) { SetResourceId(value); return *this;} /** *

The identifier for the Resource resource.

*/ inline GetResourceRequest& WithResourceId(Aws::String&& value) { SetResourceId(std::move(value)); return *this;} /** *

The identifier for the Resource resource.

*/ inline GetResourceRequest& WithResourceId(const char* value) { SetResourceId(value); return *this;} /** *

A query parameter to retrieve the specified resources embedded in the * returned Resource representation in the response. This embed * parameter value is a list of comma-separated strings. Currently, the request * supports only retrieval of the embedded Method resources this way. The query * parameter value must be a single-valued list and contain the * "methods" string. For example, GET * /restapis/{restapi_id}/resources/{resource_id}?embed=methods.

*/ inline const Aws::Vector& GetEmbed() const{ return m_embed; } /** *

A query parameter to retrieve the specified resources embedded in the * returned Resource representation in the response. This embed * parameter value is a list of comma-separated strings. Currently, the request * supports only retrieval of the embedded Method resources this way. The query * parameter value must be a single-valued list and contain the * "methods" string. For example, GET * /restapis/{restapi_id}/resources/{resource_id}?embed=methods.

*/ inline bool EmbedHasBeenSet() const { return m_embedHasBeenSet; } /** *

A query parameter to retrieve the specified resources embedded in the * returned Resource representation in the response. This embed * parameter value is a list of comma-separated strings. Currently, the request * supports only retrieval of the embedded Method resources this way. The query * parameter value must be a single-valued list and contain the * "methods" string. For example, GET * /restapis/{restapi_id}/resources/{resource_id}?embed=methods.

*/ inline void SetEmbed(const Aws::Vector& value) { m_embedHasBeenSet = true; m_embed = value; } /** *

A query parameter to retrieve the specified resources embedded in the * returned Resource representation in the response. This embed * parameter value is a list of comma-separated strings. Currently, the request * supports only retrieval of the embedded Method resources this way. The query * parameter value must be a single-valued list and contain the * "methods" string. For example, GET * /restapis/{restapi_id}/resources/{resource_id}?embed=methods.

*/ inline void SetEmbed(Aws::Vector&& value) { m_embedHasBeenSet = true; m_embed = std::move(value); } /** *

A query parameter to retrieve the specified resources embedded in the * returned Resource representation in the response. This embed * parameter value is a list of comma-separated strings. Currently, the request * supports only retrieval of the embedded Method resources this way. The query * parameter value must be a single-valued list and contain the * "methods" string. For example, GET * /restapis/{restapi_id}/resources/{resource_id}?embed=methods.

*/ inline GetResourceRequest& WithEmbed(const Aws::Vector& value) { SetEmbed(value); return *this;} /** *

A query parameter to retrieve the specified resources embedded in the * returned Resource representation in the response. This embed * parameter value is a list of comma-separated strings. Currently, the request * supports only retrieval of the embedded Method resources this way. The query * parameter value must be a single-valued list and contain the * "methods" string. For example, GET * /restapis/{restapi_id}/resources/{resource_id}?embed=methods.

*/ inline GetResourceRequest& WithEmbed(Aws::Vector&& value) { SetEmbed(std::move(value)); return *this;} /** *

A query parameter to retrieve the specified resources embedded in the * returned Resource representation in the response. This embed * parameter value is a list of comma-separated strings. Currently, the request * supports only retrieval of the embedded Method resources this way. The query * parameter value must be a single-valued list and contain the * "methods" string. For example, GET * /restapis/{restapi_id}/resources/{resource_id}?embed=methods.

*/ inline GetResourceRequest& AddEmbed(const Aws::String& value) { m_embedHasBeenSet = true; m_embed.push_back(value); return *this; } /** *

A query parameter to retrieve the specified resources embedded in the * returned Resource representation in the response. This embed * parameter value is a list of comma-separated strings. Currently, the request * supports only retrieval of the embedded Method resources this way. The query * parameter value must be a single-valued list and contain the * "methods" string. For example, GET * /restapis/{restapi_id}/resources/{resource_id}?embed=methods.

*/ inline GetResourceRequest& AddEmbed(Aws::String&& value) { m_embedHasBeenSet = true; m_embed.push_back(std::move(value)); return *this; } /** *

A query parameter to retrieve the specified resources embedded in the * returned Resource representation in the response. This embed * parameter value is a list of comma-separated strings. Currently, the request * supports only retrieval of the embedded Method resources this way. The query * parameter value must be a single-valued list and contain the * "methods" string. For example, GET * /restapis/{restapi_id}/resources/{resource_id}?embed=methods.

*/ inline GetResourceRequest& AddEmbed(const char* value) { m_embedHasBeenSet = true; m_embed.push_back(value); return *this; } private: Aws::String m_restApiId; bool m_restApiIdHasBeenSet = false; Aws::String m_resourceId; bool m_resourceIdHasBeenSet = false; Aws::Vector m_embed; bool m_embedHasBeenSet = false; }; } // namespace Model } // namespace APIGateway } // namespace Aws