/**
* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
* SPDX-License-Identifier: Apache-2.0.
*/
#pragma once
#include Represents an integration response.See Also:
AWS
* API Reference
Supported only for WebSocket APIs. Specifies how to handle response payload * content type conversions. Supported values are CONVERT_TO_BINARY and * CONVERT_TO_TEXT, with the following behaviors:
CONVERT_TO_BINARY: * Converts a response payload from a Base64-encoded string to the corresponding * binary blob.
CONVERT_TO_TEXT: Converts a response payload from a binary * blob to a Base64-encoded string.
If this property is not defined, the * response payload will be passed through from the integration response to the * route response or method response without modification.
*/ inline const ContentHandlingStrategy& GetContentHandlingStrategy() const{ return m_contentHandlingStrategy; } /** *Supported only for WebSocket APIs. Specifies how to handle response payload * content type conversions. Supported values are CONVERT_TO_BINARY and * CONVERT_TO_TEXT, with the following behaviors:
CONVERT_TO_BINARY: * Converts a response payload from a Base64-encoded string to the corresponding * binary blob.
CONVERT_TO_TEXT: Converts a response payload from a binary * blob to a Base64-encoded string.
If this property is not defined, the * response payload will be passed through from the integration response to the * route response or method response without modification.
*/ inline bool ContentHandlingStrategyHasBeenSet() const { return m_contentHandlingStrategyHasBeenSet; } /** *Supported only for WebSocket APIs. Specifies how to handle response payload * content type conversions. Supported values are CONVERT_TO_BINARY and * CONVERT_TO_TEXT, with the following behaviors:
CONVERT_TO_BINARY: * Converts a response payload from a Base64-encoded string to the corresponding * binary blob.
CONVERT_TO_TEXT: Converts a response payload from a binary * blob to a Base64-encoded string.
If this property is not defined, the * response payload will be passed through from the integration response to the * route response or method response without modification.
*/ inline void SetContentHandlingStrategy(const ContentHandlingStrategy& value) { m_contentHandlingStrategyHasBeenSet = true; m_contentHandlingStrategy = value; } /** *Supported only for WebSocket APIs. Specifies how to handle response payload * content type conversions. Supported values are CONVERT_TO_BINARY and * CONVERT_TO_TEXT, with the following behaviors:
CONVERT_TO_BINARY: * Converts a response payload from a Base64-encoded string to the corresponding * binary blob.
CONVERT_TO_TEXT: Converts a response payload from a binary * blob to a Base64-encoded string.
If this property is not defined, the * response payload will be passed through from the integration response to the * route response or method response without modification.
*/ inline void SetContentHandlingStrategy(ContentHandlingStrategy&& value) { m_contentHandlingStrategyHasBeenSet = true; m_contentHandlingStrategy = std::move(value); } /** *Supported only for WebSocket APIs. Specifies how to handle response payload * content type conversions. Supported values are CONVERT_TO_BINARY and * CONVERT_TO_TEXT, with the following behaviors:
CONVERT_TO_BINARY: * Converts a response payload from a Base64-encoded string to the corresponding * binary blob.
CONVERT_TO_TEXT: Converts a response payload from a binary * blob to a Base64-encoded string.
If this property is not defined, the * response payload will be passed through from the integration response to the * route response or method response without modification.
*/ inline IntegrationResponse& WithContentHandlingStrategy(const ContentHandlingStrategy& value) { SetContentHandlingStrategy(value); return *this;} /** *Supported only for WebSocket APIs. Specifies how to handle response payload * content type conversions. Supported values are CONVERT_TO_BINARY and * CONVERT_TO_TEXT, with the following behaviors:
CONVERT_TO_BINARY: * Converts a response payload from a Base64-encoded string to the corresponding * binary blob.
CONVERT_TO_TEXT: Converts a response payload from a binary * blob to a Base64-encoded string.
If this property is not defined, the * response payload will be passed through from the integration response to the * route response or method response without modification.
*/ inline IntegrationResponse& WithContentHandlingStrategy(ContentHandlingStrategy&& value) { SetContentHandlingStrategy(std::move(value)); return *this;} /** *The integration response ID.
*/ inline const Aws::String& GetIntegrationResponseId() const{ return m_integrationResponseId; } /** *The integration response ID.
*/ inline bool IntegrationResponseIdHasBeenSet() const { return m_integrationResponseIdHasBeenSet; } /** *The integration response ID.
*/ inline void SetIntegrationResponseId(const Aws::String& value) { m_integrationResponseIdHasBeenSet = true; m_integrationResponseId = value; } /** *The integration response ID.
*/ inline void SetIntegrationResponseId(Aws::String&& value) { m_integrationResponseIdHasBeenSet = true; m_integrationResponseId = std::move(value); } /** *The integration response ID.
*/ inline void SetIntegrationResponseId(const char* value) { m_integrationResponseIdHasBeenSet = true; m_integrationResponseId.assign(value); } /** *The integration response ID.
*/ inline IntegrationResponse& WithIntegrationResponseId(const Aws::String& value) { SetIntegrationResponseId(value); return *this;} /** *The integration response ID.
*/ inline IntegrationResponse& WithIntegrationResponseId(Aws::String&& value) { SetIntegrationResponseId(std::move(value)); return *this;} /** *The integration response ID.
*/ inline IntegrationResponse& WithIntegrationResponseId(const char* value) { SetIntegrationResponseId(value); return *this;} /** *The integration response key.
*/ inline const Aws::String& GetIntegrationResponseKey() const{ return m_integrationResponseKey; } /** *The integration response key.
*/ inline bool IntegrationResponseKeyHasBeenSet() const { return m_integrationResponseKeyHasBeenSet; } /** *The integration response key.
*/ inline void SetIntegrationResponseKey(const Aws::String& value) { m_integrationResponseKeyHasBeenSet = true; m_integrationResponseKey = value; } /** *The integration response key.
*/ inline void SetIntegrationResponseKey(Aws::String&& value) { m_integrationResponseKeyHasBeenSet = true; m_integrationResponseKey = std::move(value); } /** *The integration response key.
*/ inline void SetIntegrationResponseKey(const char* value) { m_integrationResponseKeyHasBeenSet = true; m_integrationResponseKey.assign(value); } /** *The integration response key.
*/ inline IntegrationResponse& WithIntegrationResponseKey(const Aws::String& value) { SetIntegrationResponseKey(value); return *this;} /** *The integration response key.
*/ inline IntegrationResponse& WithIntegrationResponseKey(Aws::String&& value) { SetIntegrationResponseKey(std::move(value)); return *this;} /** *The integration response key.
*/ inline IntegrationResponse& WithIntegrationResponseKey(const char* value) { SetIntegrationResponseKey(value); return *this;} /** *A key-value map specifying response parameters that are passed to the method * response from the backend. The key is a method response header parameter name * and the mapped value is an integration response header value, a static value * enclosed within a pair of single quotes, or a JSON expression from the * integration response body. The mapping key must match the pattern of * method.response.header.{name}, where name is a valid and unique header name. The * mapped non-static value must match the pattern of * integration.response.header.{name} or * integration.response.body.{JSON-expression}, where name is a valid and unique * response header name and JSON-expression is a valid JSON expression without the * $ prefix.
*/ inline const Aws::MapA key-value map specifying response parameters that are passed to the method * response from the backend. The key is a method response header parameter name * and the mapped value is an integration response header value, a static value * enclosed within a pair of single quotes, or a JSON expression from the * integration response body. The mapping key must match the pattern of * method.response.header.{name}, where name is a valid and unique header name. The * mapped non-static value must match the pattern of * integration.response.header.{name} or * integration.response.body.{JSON-expression}, where name is a valid and unique * response header name and JSON-expression is a valid JSON expression without the * $ prefix.
*/ inline bool ResponseParametersHasBeenSet() const { return m_responseParametersHasBeenSet; } /** *A key-value map specifying response parameters that are passed to the method * response from the backend. The key is a method response header parameter name * and the mapped value is an integration response header value, a static value * enclosed within a pair of single quotes, or a JSON expression from the * integration response body. The mapping key must match the pattern of * method.response.header.{name}, where name is a valid and unique header name. The * mapped non-static value must match the pattern of * integration.response.header.{name} or * integration.response.body.{JSON-expression}, where name is a valid and unique * response header name and JSON-expression is a valid JSON expression without the * $ prefix.
*/ inline void SetResponseParameters(const Aws::MapA key-value map specifying response parameters that are passed to the method * response from the backend. The key is a method response header parameter name * and the mapped value is an integration response header value, a static value * enclosed within a pair of single quotes, or a JSON expression from the * integration response body. The mapping key must match the pattern of * method.response.header.{name}, where name is a valid and unique header name. The * mapped non-static value must match the pattern of * integration.response.header.{name} or * integration.response.body.{JSON-expression}, where name is a valid and unique * response header name and JSON-expression is a valid JSON expression without the * $ prefix.
*/ inline void SetResponseParameters(Aws::MapA key-value map specifying response parameters that are passed to the method * response from the backend. The key is a method response header parameter name * and the mapped value is an integration response header value, a static value * enclosed within a pair of single quotes, or a JSON expression from the * integration response body. The mapping key must match the pattern of * method.response.header.{name}, where name is a valid and unique header name. The * mapped non-static value must match the pattern of * integration.response.header.{name} or * integration.response.body.{JSON-expression}, where name is a valid and unique * response header name and JSON-expression is a valid JSON expression without the * $ prefix.
*/ inline IntegrationResponse& WithResponseParameters(const Aws::MapA key-value map specifying response parameters that are passed to the method * response from the backend. The key is a method response header parameter name * and the mapped value is an integration response header value, a static value * enclosed within a pair of single quotes, or a JSON expression from the * integration response body. The mapping key must match the pattern of * method.response.header.{name}, where name is a valid and unique header name. The * mapped non-static value must match the pattern of * integration.response.header.{name} or * integration.response.body.{JSON-expression}, where name is a valid and unique * response header name and JSON-expression is a valid JSON expression without the * $ prefix.
*/ inline IntegrationResponse& WithResponseParameters(Aws::MapA key-value map specifying response parameters that are passed to the method * response from the backend. The key is a method response header parameter name * and the mapped value is an integration response header value, a static value * enclosed within a pair of single quotes, or a JSON expression from the * integration response body. The mapping key must match the pattern of * method.response.header.{name}, where name is a valid and unique header name. The * mapped non-static value must match the pattern of * integration.response.header.{name} or * integration.response.body.{JSON-expression}, where name is a valid and unique * response header name and JSON-expression is a valid JSON expression without the * $ prefix.
*/ inline IntegrationResponse& AddResponseParameters(const Aws::String& key, const Aws::String& value) { m_responseParametersHasBeenSet = true; m_responseParameters.emplace(key, value); return *this; } /** *A key-value map specifying response parameters that are passed to the method * response from the backend. The key is a method response header parameter name * and the mapped value is an integration response header value, a static value * enclosed within a pair of single quotes, or a JSON expression from the * integration response body. The mapping key must match the pattern of * method.response.header.{name}, where name is a valid and unique header name. The * mapped non-static value must match the pattern of * integration.response.header.{name} or * integration.response.body.{JSON-expression}, where name is a valid and unique * response header name and JSON-expression is a valid JSON expression without the * $ prefix.
*/ inline IntegrationResponse& AddResponseParameters(Aws::String&& key, const Aws::String& value) { m_responseParametersHasBeenSet = true; m_responseParameters.emplace(std::move(key), value); return *this; } /** *A key-value map specifying response parameters that are passed to the method * response from the backend. The key is a method response header parameter name * and the mapped value is an integration response header value, a static value * enclosed within a pair of single quotes, or a JSON expression from the * integration response body. The mapping key must match the pattern of * method.response.header.{name}, where name is a valid and unique header name. The * mapped non-static value must match the pattern of * integration.response.header.{name} or * integration.response.body.{JSON-expression}, where name is a valid and unique * response header name and JSON-expression is a valid JSON expression without the * $ prefix.
*/ inline IntegrationResponse& AddResponseParameters(const Aws::String& key, Aws::String&& value) { m_responseParametersHasBeenSet = true; m_responseParameters.emplace(key, std::move(value)); return *this; } /** *A key-value map specifying response parameters that are passed to the method * response from the backend. The key is a method response header parameter name * and the mapped value is an integration response header value, a static value * enclosed within a pair of single quotes, or a JSON expression from the * integration response body. The mapping key must match the pattern of * method.response.header.{name}, where name is a valid and unique header name. The * mapped non-static value must match the pattern of * integration.response.header.{name} or * integration.response.body.{JSON-expression}, where name is a valid and unique * response header name and JSON-expression is a valid JSON expression without the * $ prefix.
*/ inline IntegrationResponse& AddResponseParameters(Aws::String&& key, Aws::String&& value) { m_responseParametersHasBeenSet = true; m_responseParameters.emplace(std::move(key), std::move(value)); return *this; } /** *A key-value map specifying response parameters that are passed to the method * response from the backend. The key is a method response header parameter name * and the mapped value is an integration response header value, a static value * enclosed within a pair of single quotes, or a JSON expression from the * integration response body. The mapping key must match the pattern of * method.response.header.{name}, where name is a valid and unique header name. The * mapped non-static value must match the pattern of * integration.response.header.{name} or * integration.response.body.{JSON-expression}, where name is a valid and unique * response header name and JSON-expression is a valid JSON expression without the * $ prefix.
*/ inline IntegrationResponse& AddResponseParameters(const char* key, Aws::String&& value) { m_responseParametersHasBeenSet = true; m_responseParameters.emplace(key, std::move(value)); return *this; } /** *A key-value map specifying response parameters that are passed to the method * response from the backend. The key is a method response header parameter name * and the mapped value is an integration response header value, a static value * enclosed within a pair of single quotes, or a JSON expression from the * integration response body. The mapping key must match the pattern of * method.response.header.{name}, where name is a valid and unique header name. The * mapped non-static value must match the pattern of * integration.response.header.{name} or * integration.response.body.{JSON-expression}, where name is a valid and unique * response header name and JSON-expression is a valid JSON expression without the * $ prefix.
*/ inline IntegrationResponse& AddResponseParameters(Aws::String&& key, const char* value) { m_responseParametersHasBeenSet = true; m_responseParameters.emplace(std::move(key), value); return *this; } /** *A key-value map specifying response parameters that are passed to the method * response from the backend. The key is a method response header parameter name * and the mapped value is an integration response header value, a static value * enclosed within a pair of single quotes, or a JSON expression from the * integration response body. The mapping key must match the pattern of * method.response.header.{name}, where name is a valid and unique header name. The * mapped non-static value must match the pattern of * integration.response.header.{name} or * integration.response.body.{JSON-expression}, where name is a valid and unique * response header name and JSON-expression is a valid JSON expression without the * $ prefix.
*/ inline IntegrationResponse& AddResponseParameters(const char* key, const char* value) { m_responseParametersHasBeenSet = true; m_responseParameters.emplace(key, value); return *this; } /** *The collection of response templates for the integration response as a * string-to-string map of key-value pairs. Response templates are represented as a * key/value map, with a content-type as the key and a template as the value.
*/ inline const Aws::MapThe collection of response templates for the integration response as a * string-to-string map of key-value pairs. Response templates are represented as a * key/value map, with a content-type as the key and a template as the value.
*/ inline bool ResponseTemplatesHasBeenSet() const { return m_responseTemplatesHasBeenSet; } /** *The collection of response templates for the integration response as a * string-to-string map of key-value pairs. Response templates are represented as a * key/value map, with a content-type as the key and a template as the value.
*/ inline void SetResponseTemplates(const Aws::MapThe collection of response templates for the integration response as a * string-to-string map of key-value pairs. Response templates are represented as a * key/value map, with a content-type as the key and a template as the value.
*/ inline void SetResponseTemplates(Aws::MapThe collection of response templates for the integration response as a * string-to-string map of key-value pairs. Response templates are represented as a * key/value map, with a content-type as the key and a template as the value.
*/ inline IntegrationResponse& WithResponseTemplates(const Aws::MapThe collection of response templates for the integration response as a * string-to-string map of key-value pairs. Response templates are represented as a * key/value map, with a content-type as the key and a template as the value.
*/ inline IntegrationResponse& WithResponseTemplates(Aws::MapThe collection of response templates for the integration response as a * string-to-string map of key-value pairs. Response templates are represented as a * key/value map, with a content-type as the key and a template as the value.
*/ inline IntegrationResponse& AddResponseTemplates(const Aws::String& key, const Aws::String& value) { m_responseTemplatesHasBeenSet = true; m_responseTemplates.emplace(key, value); return *this; } /** *The collection of response templates for the integration response as a * string-to-string map of key-value pairs. Response templates are represented as a * key/value map, with a content-type as the key and a template as the value.
*/ inline IntegrationResponse& AddResponseTemplates(Aws::String&& key, const Aws::String& value) { m_responseTemplatesHasBeenSet = true; m_responseTemplates.emplace(std::move(key), value); return *this; } /** *The collection of response templates for the integration response as a * string-to-string map of key-value pairs. Response templates are represented as a * key/value map, with a content-type as the key and a template as the value.
*/ inline IntegrationResponse& AddResponseTemplates(const Aws::String& key, Aws::String&& value) { m_responseTemplatesHasBeenSet = true; m_responseTemplates.emplace(key, std::move(value)); return *this; } /** *The collection of response templates for the integration response as a * string-to-string map of key-value pairs. Response templates are represented as a * key/value map, with a content-type as the key and a template as the value.
*/ inline IntegrationResponse& AddResponseTemplates(Aws::String&& key, Aws::String&& value) { m_responseTemplatesHasBeenSet = true; m_responseTemplates.emplace(std::move(key), std::move(value)); return *this; } /** *The collection of response templates for the integration response as a * string-to-string map of key-value pairs. Response templates are represented as a * key/value map, with a content-type as the key and a template as the value.
*/ inline IntegrationResponse& AddResponseTemplates(const char* key, Aws::String&& value) { m_responseTemplatesHasBeenSet = true; m_responseTemplates.emplace(key, std::move(value)); return *this; } /** *The collection of response templates for the integration response as a * string-to-string map of key-value pairs. Response templates are represented as a * key/value map, with a content-type as the key and a template as the value.
*/ inline IntegrationResponse& AddResponseTemplates(Aws::String&& key, const char* value) { m_responseTemplatesHasBeenSet = true; m_responseTemplates.emplace(std::move(key), value); return *this; } /** *The collection of response templates for the integration response as a * string-to-string map of key-value pairs. Response templates are represented as a * key/value map, with a content-type as the key and a template as the value.
*/ inline IntegrationResponse& AddResponseTemplates(const char* key, const char* value) { m_responseTemplatesHasBeenSet = true; m_responseTemplates.emplace(key, value); return *this; } /** *The template selection expressions for the integration response.
*/ inline const Aws::String& GetTemplateSelectionExpression() const{ return m_templateSelectionExpression; } /** *The template selection expressions for the integration response.
*/ inline bool TemplateSelectionExpressionHasBeenSet() const { return m_templateSelectionExpressionHasBeenSet; } /** *The template selection expressions for the integration response.
*/ inline void SetTemplateSelectionExpression(const Aws::String& value) { m_templateSelectionExpressionHasBeenSet = true; m_templateSelectionExpression = value; } /** *The template selection expressions for the integration response.
*/ inline void SetTemplateSelectionExpression(Aws::String&& value) { m_templateSelectionExpressionHasBeenSet = true; m_templateSelectionExpression = std::move(value); } /** *The template selection expressions for the integration response.
*/ inline void SetTemplateSelectionExpression(const char* value) { m_templateSelectionExpressionHasBeenSet = true; m_templateSelectionExpression.assign(value); } /** *The template selection expressions for the integration response.
*/ inline IntegrationResponse& WithTemplateSelectionExpression(const Aws::String& value) { SetTemplateSelectionExpression(value); return *this;} /** *The template selection expressions for the integration response.
*/ inline IntegrationResponse& WithTemplateSelectionExpression(Aws::String&& value) { SetTemplateSelectionExpression(std::move(value)); return *this;} /** *The template selection expressions for the integration response.
*/ inline IntegrationResponse& WithTemplateSelectionExpression(const char* value) { SetTemplateSelectionExpression(value); return *this;} private: ContentHandlingStrategy m_contentHandlingStrategy; bool m_contentHandlingStrategyHasBeenSet = false; Aws::String m_integrationResponseId; bool m_integrationResponseIdHasBeenSet = false; Aws::String m_integrationResponseKey; bool m_integrationResponseKeyHasBeenSet = false; Aws::Map