/*
* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License").
* You may not use this file except in compliance with the License.
* A copy of the License is located at
*
* http://aws.amazon.com/apache2.0
*
* or in the "license" file accompanying this file. This file is distributed
* on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
* express or implied. See the License for the specific language governing
* permissions and limitations under the License.
*/
/*
* Do not modify this file. This file is generated from the appmesh-2019-01-25.normal.json service model.
*/
using System;
using System.Collections.Generic;
using System.Xml.Serialization;
using System.Text;
using System.IO;
using System.Net;
using Amazon.Runtime;
using Amazon.Runtime.Internal;
namespace Amazon.AppMesh.Model
{
///
/// An object that represents the requirements for a route to match HTTP requests for
/// a virtual router.
///
public partial class HttpRouteMatch
{
private List _headers = new List();
private HttpMethod _method;
private HttpPathMatch _path;
private int? _port;
private string _prefix;
private List _queryParameters = new List();
private HttpScheme _scheme;
///
/// Gets and sets the property Headers.
///
/// The client request headers to match on.
///
///
[AWSProperty(Min=1, Max=10)]
public List Headers
{
get { return this._headers; }
set { this._headers = value; }
}
// Check to see if Headers property is set
internal bool IsSetHeaders()
{
return this._headers != null && this._headers.Count > 0;
}
///
/// Gets and sets the property Method.
///
/// The client request method to match on. Specify only one.
///
///
public HttpMethod Method
{
get { return this._method; }
set { this._method = value; }
}
// Check to see if Method property is set
internal bool IsSetMethod()
{
return this._method != null;
}
///
/// Gets and sets the property Path.
///
/// The client request path to match on.
///
///
public HttpPathMatch Path
{
get { return this._path; }
set { this._path = value; }
}
// Check to see if Path property is set
internal bool IsSetPath()
{
return this._path != null;
}
///
/// Gets and sets the property Port.
///
/// The port number to match on.
///
///
[AWSProperty(Min=1, Max=65535)]
public int Port
{
get { return this._port.GetValueOrDefault(); }
set { this._port = value; }
}
// Check to see if Port property is set
internal bool IsSetPort()
{
return this._port.HasValue;
}
///
/// Gets and sets the property 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
.
///
///
public string Prefix
{
get { return this._prefix; }
set { this._prefix = value; }
}
// Check to see if Prefix property is set
internal bool IsSetPrefix()
{
return this._prefix != null;
}
///
/// Gets and sets the property QueryParameters.
///
/// The client request query parameters to match on.
///
///
[AWSProperty(Min=1, Max=10)]
public List QueryParameters
{
get { return this._queryParameters; }
set { this._queryParameters = value; }
}
// Check to see if QueryParameters property is set
internal bool IsSetQueryParameters()
{
return this._queryParameters != null && this._queryParameters.Count > 0;
}
///
/// Gets and sets the property Scheme.
///
/// The client request scheme to match on. Specify only one. Applicable only for HTTP2
/// routes.
///
///
public HttpScheme Scheme
{
get { return this._scheme; }
set { this._scheme = value; }
}
// Check to see if Scheme property is set
internal bool IsSetScheme()
{
return this._scheme != null;
}
}
}