/** * 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 #include #include namespace Aws { namespace Utils { namespace Json { class JsonValue; class JsonView; } // namespace Json } // namespace Utils namespace AppMesh { namespace Model { /** *

An object that represents the requirements for a route to match HTTP requests * for a virtual router.

See Also:

AWS * API Reference

*/ class HttpRouteMatch { public: AWS_APPMESH_API HttpRouteMatch(); AWS_APPMESH_API HttpRouteMatch(Aws::Utils::Json::JsonView jsonValue); AWS_APPMESH_API HttpRouteMatch& operator=(Aws::Utils::Json::JsonView jsonValue); AWS_APPMESH_API Aws::Utils::Json::JsonValue Jsonize() const; /** *

The client request headers to match on.

*/ inline const Aws::Vector& GetHeaders() const{ return m_headers; } /** *

The client request headers to match on.

*/ inline bool HeadersHasBeenSet() const { return m_headersHasBeenSet; } /** *

The client request headers to match on.

*/ inline void SetHeaders(const Aws::Vector& value) { m_headersHasBeenSet = true; m_headers = value; } /** *

The client request headers to match on.

*/ inline void SetHeaders(Aws::Vector&& value) { m_headersHasBeenSet = true; m_headers = std::move(value); } /** *

The client request headers to match on.

*/ inline HttpRouteMatch& WithHeaders(const Aws::Vector& value) { SetHeaders(value); return *this;} /** *

The client request headers to match on.

*/ inline HttpRouteMatch& WithHeaders(Aws::Vector&& value) { SetHeaders(std::move(value)); return *this;} /** *

The client request headers to match on.

*/ inline HttpRouteMatch& AddHeaders(const HttpRouteHeader& value) { m_headersHasBeenSet = true; m_headers.push_back(value); return *this; } /** *

The client request headers to match on.

*/ inline HttpRouteMatch& AddHeaders(HttpRouteHeader&& value) { m_headersHasBeenSet = true; m_headers.push_back(std::move(value)); return *this; } /** *

The client request method to match on. Specify only one.

*/ inline const HttpMethod& GetMethod() const{ return m_method; } /** *

The client request method to match on. Specify only one.

*/ inline bool MethodHasBeenSet() const { return m_methodHasBeenSet; } /** *

The client request method to match on. Specify only one.

*/ inline void SetMethod(const HttpMethod& value) { m_methodHasBeenSet = true; m_method = value; } /** *

The client request method to match on. Specify only one.

*/ inline void SetMethod(HttpMethod&& value) { m_methodHasBeenSet = true; m_method = std::move(value); } /** *

The client request method to match on. Specify only one.

*/ inline HttpRouteMatch& WithMethod(const HttpMethod& value) { SetMethod(value); return *this;} /** *

The client request method to match on. Specify only one.

*/ inline HttpRouteMatch& WithMethod(HttpMethod&& value) { SetMethod(std::move(value)); return *this;} /** *

The client request path to match on.

*/ inline const HttpPathMatch& GetPath() const{ return m_path; } /** *

The client request path to match on.

*/ inline bool PathHasBeenSet() const { return m_pathHasBeenSet; } /** *

The client request path to match on.

*/ inline void SetPath(const HttpPathMatch& value) { m_pathHasBeenSet = true; m_path = value; } /** *

The client request path to match on.

*/ inline void SetPath(HttpPathMatch&& value) { m_pathHasBeenSet = true; m_path = std::move(value); } /** *

The client request path to match on.

*/ inline HttpRouteMatch& WithPath(const HttpPathMatch& value) { SetPath(value); return *this;} /** *

The client request path to match on.

*/ inline HttpRouteMatch& WithPath(HttpPathMatch&& value) { SetPath(std::move(value)); return *this;} /** *

The port number to match on.

*/ inline int GetPort() const{ return m_port; } /** *

The port number to match on.

*/ inline bool PortHasBeenSet() const { return m_portHasBeenSet; } /** *

The port number to match on.

*/ inline void SetPort(int value) { m_portHasBeenSet = true; m_port = value; } /** *

The port number to match on.

*/ inline HttpRouteMatch& WithPort(int value) { SetPort(value); return *this;} /** *

Specifies the path to match requests with. This parameter must always start * with /, which by itself matches all requests to the virtual service * name. You can also match for path-based routing of requests. For example, if * your virtual service name is my-service.local and you want the * route to match requests to my-service.local/metrics, your prefix * should be /metrics.

*/ inline const Aws::String& GetPrefix() const{ return m_prefix; } /** *

Specifies the path to match requests with. This parameter must always start * with /, which by itself matches all requests to the virtual service * name. You can also match for path-based routing of requests. For example, if * your virtual service name is my-service.local and you want the * route to match requests to my-service.local/metrics, your prefix * should be /metrics.

*/ inline bool PrefixHasBeenSet() const { return m_prefixHasBeenSet; } /** *

Specifies the path to match requests with. This parameter must always start * with /, which by itself matches all requests to the virtual service * name. You can also match for path-based routing of requests. For example, if * your virtual service name is my-service.local and you want the * route to match requests to my-service.local/metrics, your prefix * should be /metrics.

*/ inline void SetPrefix(const Aws::String& value) { m_prefixHasBeenSet = true; m_prefix = value; } /** *

Specifies the path to match requests with. This parameter must always start * with /, which by itself matches all requests to the virtual service * name. You can also match for path-based routing of requests. For example, if * your virtual service name is my-service.local and you want the * route to match requests to my-service.local/metrics, your prefix * should be /metrics.

*/ inline void SetPrefix(Aws::String&& value) { m_prefixHasBeenSet = true; m_prefix = std::move(value); } /** *

Specifies the path to match requests with. This parameter must always start * with /, which by itself matches all requests to the virtual service * name. You can also match for path-based routing of requests. For example, if * your virtual service name is my-service.local and you want the * route to match requests to my-service.local/metrics, your prefix * should be /metrics.

*/ inline void SetPrefix(const char* value) { m_prefixHasBeenSet = true; m_prefix.assign(value); } /** *

Specifies the path to match requests with. This parameter must always start * with /, which by itself matches all requests to the virtual service * name. You can also match for path-based routing of requests. For example, if * your virtual service name is my-service.local and you want the * route to match requests to my-service.local/metrics, your prefix * should be /metrics.

*/ inline HttpRouteMatch& WithPrefix(const Aws::String& value) { SetPrefix(value); return *this;} /** *

Specifies the path to match requests with. This parameter must always start * with /, which by itself matches all requests to the virtual service * name. You can also match for path-based routing of requests. For example, if * your virtual service name is my-service.local and you want the * route to match requests to my-service.local/metrics, your prefix * should be /metrics.

*/ inline HttpRouteMatch& WithPrefix(Aws::String&& value) { SetPrefix(std::move(value)); return *this;} /** *

Specifies the path to match requests with. This parameter must always start * with /, which by itself matches all requests to the virtual service * name. You can also match for path-based routing of requests. For example, if * your virtual service name is my-service.local and you want the * route to match requests to my-service.local/metrics, your prefix * should be /metrics.

*/ inline HttpRouteMatch& WithPrefix(const char* value) { SetPrefix(value); return *this;} /** *

The client request query parameters to match on.

*/ inline const Aws::Vector& GetQueryParameters() const{ return m_queryParameters; } /** *

The client request query parameters to match on.

*/ inline bool QueryParametersHasBeenSet() const { return m_queryParametersHasBeenSet; } /** *

The client request query parameters to match on.

*/ inline void SetQueryParameters(const Aws::Vector& value) { m_queryParametersHasBeenSet = true; m_queryParameters = value; } /** *

The client request query parameters to match on.

*/ inline void SetQueryParameters(Aws::Vector&& value) { m_queryParametersHasBeenSet = true; m_queryParameters = std::move(value); } /** *

The client request query parameters to match on.

*/ inline HttpRouteMatch& WithQueryParameters(const Aws::Vector& value) { SetQueryParameters(value); return *this;} /** *

The client request query parameters to match on.

*/ inline HttpRouteMatch& WithQueryParameters(Aws::Vector&& value) { SetQueryParameters(std::move(value)); return *this;} /** *

The client request query parameters to match on.

*/ inline HttpRouteMatch& AddQueryParameters(const HttpQueryParameter& value) { m_queryParametersHasBeenSet = true; m_queryParameters.push_back(value); return *this; } /** *

The client request query parameters to match on.

*/ inline HttpRouteMatch& AddQueryParameters(HttpQueryParameter&& value) { m_queryParametersHasBeenSet = true; m_queryParameters.push_back(std::move(value)); return *this; } /** *

The client request scheme to match on. Specify only one. Applicable only for * HTTP2 routes.

*/ inline const HttpScheme& GetScheme() const{ return m_scheme; } /** *

The client request scheme to match on. Specify only one. Applicable only for * HTTP2 routes.

*/ inline bool SchemeHasBeenSet() const { return m_schemeHasBeenSet; } /** *

The client request scheme to match on. Specify only one. Applicable only for * HTTP2 routes.

*/ inline void SetScheme(const HttpScheme& value) { m_schemeHasBeenSet = true; m_scheme = value; } /** *

The client request scheme to match on. Specify only one. Applicable only for * HTTP2 routes.

*/ inline void SetScheme(HttpScheme&& value) { m_schemeHasBeenSet = true; m_scheme = std::move(value); } /** *

The client request scheme to match on. Specify only one. Applicable only for * HTTP2 routes.

*/ inline HttpRouteMatch& WithScheme(const HttpScheme& value) { SetScheme(value); return *this;} /** *

The client request scheme to match on. Specify only one. Applicable only for * HTTP2 routes.

*/ inline HttpRouteMatch& WithScheme(HttpScheme&& value) { SetScheme(std::move(value)); return *this;} private: Aws::Vector m_headers; bool m_headersHasBeenSet = false; HttpMethod m_method; bool m_methodHasBeenSet = false; HttpPathMatch m_path; bool m_pathHasBeenSet = false; int m_port; bool m_portHasBeenSet = false; Aws::String m_prefix; bool m_prefixHasBeenSet = false; Aws::Vector m_queryParameters; bool m_queryParametersHasBeenSet = false; HttpScheme m_scheme; bool m_schemeHasBeenSet = false; }; } // namespace Model } // namespace AppMesh } // namespace Aws