Files

170 lines
10 KiB
C
Raw Permalink Normal View History

/**
* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
* SPDX-License-Identifier: Apache-2.0.
*/
#pragma once
#include <aws/apigateway/APIGateway_EXPORTS.h>
#include <aws/core/utils/memory/stl/AWSString.h>
#include <aws/core/utils/memory/stl/AWSMap.h>
#include <aws/apigateway/model/ContentHandlingStrategy.h>
#include <utility>
namespace Aws
{
template<typename RESULT_TYPE>
class AmazonWebServiceResult;
namespace Utils
{
namespace Json
{
class JsonValue;
} // namespace Json
} // namespace Utils
namespace APIGateway
{
namespace Model
{
/**
* <p>Represents an integration response. The status code must map to an existing
* MethodResponse, and parameters and templates can be used to transform the
* back-end response.</p><p><h3>See Also:</h3> <a
* href="http://docs.aws.amazon.com/goto/WebAPI/apigateway-2015-07-09/IntegrationResponse">AWS
* API Reference</a></p>
*/
class GetIntegrationResponseResult
{
public:
AWS_APIGATEWAY_API GetIntegrationResponseResult();
AWS_APIGATEWAY_API GetIntegrationResponseResult(const Aws::AmazonWebServiceResult<Aws::Utils::Json::JsonValue>& result);
AWS_APIGATEWAY_API GetIntegrationResponseResult& operator=(const Aws::AmazonWebServiceResult<Aws::Utils::Json::JsonValue>& result);
///@{
/**
* <p>Specifies the status code that is used to map the integration response to an
* existing MethodResponse.</p>
*/
inline const Aws::String& GetStatusCode() const{ return m_statusCode; }
inline void SetStatusCode(const Aws::String& value) { m_statusCode = value; }
inline void SetStatusCode(Aws::String&& value) { m_statusCode = std::move(value); }
inline void SetStatusCode(const char* value) { m_statusCode.assign(value); }
inline GetIntegrationResponseResult& WithStatusCode(const Aws::String& value) { SetStatusCode(value); return *this;}
inline GetIntegrationResponseResult& WithStatusCode(Aws::String&& value) { SetStatusCode(std::move(value)); return *this;}
inline GetIntegrationResponseResult& WithStatusCode(const char* value) { SetStatusCode(value); return *this;}
///@}
///@{
/**
* <p>Specifies the regular expression (regex) pattern used to choose an
* integration response based on the response from the back end. For example, if
* the success response returns nothing and the error response returns some string,
* you could use the <code>.+</code> regex to match error response. However, make
* sure that the error response does not contain any newline (<code>\n</code>)
* character in such cases. If the back end is an Lambda function, the Lambda
* function error header is matched. For all other HTTP and Amazon Web Services
* back ends, the HTTP status code is matched.</p>
*/
inline const Aws::String& GetSelectionPattern() const{ return m_selectionPattern; }
inline void SetSelectionPattern(const Aws::String& value) { m_selectionPattern = value; }
inline void SetSelectionPattern(Aws::String&& value) { m_selectionPattern = std::move(value); }
inline void SetSelectionPattern(const char* value) { m_selectionPattern.assign(value); }
inline GetIntegrationResponseResult& WithSelectionPattern(const Aws::String& value) { SetSelectionPattern(value); return *this;}
inline GetIntegrationResponseResult& WithSelectionPattern(Aws::String&& value) { SetSelectionPattern(std::move(value)); return *this;}
inline GetIntegrationResponseResult& WithSelectionPattern(const char* value) { SetSelectionPattern(value); return *this;}
///@}
///@{
/**
* <p>A key-value map specifying response parameters that are passed to the method
* response from the back end. 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
* <code>method.response.header.{name}</code>, where <code>name</code> is a valid
* and unique header name. The mapped non-static value must match the pattern of
* <code>integration.response.header.{name}</code> or
* <code>integration.response.body.{JSON-expression}</code>, where
* <code>name</code> is a valid and unique response header name and
* <code>JSON-expression</code> is a valid JSON expression without the
* <code>$</code> prefix.</p>
*/
inline const Aws::Map<Aws::String, Aws::String>& GetResponseParameters() const{ return m_responseParameters; }
inline void SetResponseParameters(const Aws::Map<Aws::String, Aws::String>& value) { m_responseParameters = value; }
inline void SetResponseParameters(Aws::Map<Aws::String, Aws::String>&& value) { m_responseParameters = std::move(value); }
inline GetIntegrationResponseResult& WithResponseParameters(const Aws::Map<Aws::String, Aws::String>& value) { SetResponseParameters(value); return *this;}
inline GetIntegrationResponseResult& WithResponseParameters(Aws::Map<Aws::String, Aws::String>&& value) { SetResponseParameters(std::move(value)); return *this;}
inline GetIntegrationResponseResult& AddResponseParameters(const Aws::String& key, const Aws::String& value) { m_responseParameters.emplace(key, value); return *this; }
inline GetIntegrationResponseResult& AddResponseParameters(Aws::String&& key, const Aws::String& value) { m_responseParameters.emplace(std::move(key), value); return *this; }
inline GetIntegrationResponseResult& AddResponseParameters(const Aws::String& key, Aws::String&& value) { m_responseParameters.emplace(key, std::move(value)); return *this; }
inline GetIntegrationResponseResult& AddResponseParameters(Aws::String&& key, Aws::String&& value) { m_responseParameters.emplace(std::move(key), std::move(value)); return *this; }
inline GetIntegrationResponseResult& AddResponseParameters(const char* key, Aws::String&& value) { m_responseParameters.emplace(key, std::move(value)); return *this; }
inline GetIntegrationResponseResult& AddResponseParameters(Aws::String&& key, const char* value) { m_responseParameters.emplace(std::move(key), value); return *this; }
inline GetIntegrationResponseResult& AddResponseParameters(const char* key, const char* value) { m_responseParameters.emplace(key, value); return *this; }
///@}
///@{
/**
* <p>Specifies the templates used to transform the integration response body.
* Response templates are represented as a key/value map, with a content-type as
* the key and a template as the value.</p>
*/
inline const Aws::Map<Aws::String, Aws::String>& GetResponseTemplates() const{ return m_responseTemplates; }
inline void SetResponseTemplates(const Aws::Map<Aws::String, Aws::String>& value) { m_responseTemplates = value; }
inline void SetResponseTemplates(Aws::Map<Aws::String, Aws::String>&& value) { m_responseTemplates = std::move(value); }
inline GetIntegrationResponseResult& WithResponseTemplates(const Aws::Map<Aws::String, Aws::String>& value) { SetResponseTemplates(value); return *this;}
inline GetIntegrationResponseResult& WithResponseTemplates(Aws::Map<Aws::String, Aws::String>&& value) { SetResponseTemplates(std::move(value)); return *this;}
inline GetIntegrationResponseResult& AddResponseTemplates(const Aws::String& key, const Aws::String& value) { m_responseTemplates.emplace(key, value); return *this; }
inline GetIntegrationResponseResult& AddResponseTemplates(Aws::String&& key, const Aws::String& value) { m_responseTemplates.emplace(std::move(key), value); return *this; }
inline GetIntegrationResponseResult& AddResponseTemplates(const Aws::String& key, Aws::String&& value) { m_responseTemplates.emplace(key, std::move(value)); return *this; }
inline GetIntegrationResponseResult& AddResponseTemplates(Aws::String&& key, Aws::String&& value) { m_responseTemplates.emplace(std::move(key), std::move(value)); return *this; }
inline GetIntegrationResponseResult& AddResponseTemplates(const char* key, Aws::String&& value) { m_responseTemplates.emplace(key, std::move(value)); return *this; }
inline GetIntegrationResponseResult& AddResponseTemplates(Aws::String&& key, const char* value) { m_responseTemplates.emplace(std::move(key), value); return *this; }
inline GetIntegrationResponseResult& AddResponseTemplates(const char* key, const char* value) { m_responseTemplates.emplace(key, value); return *this; }
///@}
///@{
/**
* <p>Specifies how to handle response payload content type conversions. Supported
* values are <code>CONVERT_TO_BINARY</code> and <code>CONVERT_TO_TEXT</code>, with
* the following behaviors:</p> <p>If this property is not defined, the response
* payload will be passed through from the integration response to the method
* response without modification.</p>
*/
inline const ContentHandlingStrategy& GetContentHandling() const{ return m_contentHandling; }
inline void SetContentHandling(const ContentHandlingStrategy& value) { m_contentHandling = value; }
inline void SetContentHandling(ContentHandlingStrategy&& value) { m_contentHandling = std::move(value); }
inline GetIntegrationResponseResult& WithContentHandling(const ContentHandlingStrategy& value) { SetContentHandling(value); return *this;}
inline GetIntegrationResponseResult& WithContentHandling(ContentHandlingStrategy&& value) { SetContentHandling(std::move(value)); return *this;}
///@}
///@{
inline const Aws::String& GetRequestId() const{ return m_requestId; }
inline void SetRequestId(const Aws::String& value) { m_requestId = value; }
inline void SetRequestId(Aws::String&& value) { m_requestId = std::move(value); }
inline void SetRequestId(const char* value) { m_requestId.assign(value); }
inline GetIntegrationResponseResult& WithRequestId(const Aws::String& value) { SetRequestId(value); return *this;}
inline GetIntegrationResponseResult& WithRequestId(Aws::String&& value) { SetRequestId(std::move(value)); return *this;}
inline GetIntegrationResponseResult& WithRequestId(const char* value) { SetRequestId(value); return *this;}
///@}
private:
Aws::String m_statusCode;
Aws::String m_selectionPattern;
Aws::Map<Aws::String, Aws::String> m_responseParameters;
Aws::Map<Aws::String, Aws::String> m_responseTemplates;
ContentHandlingStrategy m_contentHandling;
Aws::String m_requestId;
};
} // namespace Model
} // namespace APIGateway
} // namespace Aws