/*
 * 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 neptune-2014-10-31.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.Neptune.Model
{
    /// 
    /// Container for the parameters to the DescribeDBClusterEndpoints operation.
    /// Returns information about endpoints for an Amazon Neptune DB cluster.
    /// 
    ///   
    /// 
    /// This operation can also return information for Amazon RDS clusters and Amazon DocDB
    /// clusters.
    /// 
    ///  
    /// 
    public partial class DescribeDBClusterEndpointsRequest : AmazonNeptuneRequest
    {
        private string _dbClusterEndpointIdentifier;
        private string _dbClusterIdentifier;
        private List _filters = new List();
        private string _marker;
        private int? _maxRecords;
        /// 
        /// Gets and sets the property DBClusterEndpointIdentifier. 
        /// 
        /// The identifier of the endpoint to describe. This parameter is stored as a lowercase
        /// string.
        /// 
        /// 
        public string DBClusterEndpointIdentifier
        {
            get { return this._dbClusterEndpointIdentifier; }
            set { this._dbClusterEndpointIdentifier = value; }
        }
        // Check to see if DBClusterEndpointIdentifier property is set
        internal bool IsSetDBClusterEndpointIdentifier()
        {
            return this._dbClusterEndpointIdentifier != null;
        }
        /// 
        /// Gets and sets the property DBClusterIdentifier. 
        /// 
        /// The DB cluster identifier of the DB cluster associated with the endpoint. This parameter
        /// is stored as a lowercase string.
        /// 
        /// 
        public string DBClusterIdentifier
        {
            get { return this._dbClusterIdentifier; }
            set { this._dbClusterIdentifier = value; }
        }
        // Check to see if DBClusterIdentifier property is set
        internal bool IsSetDBClusterIdentifier()
        {
            return this._dbClusterIdentifier != null;
        }
        /// 
        /// Gets and sets the property Filters. 
        /// 
        /// A set of name-value pairs that define which endpoints to include in the output. The
        /// filters are specified as name-value pairs, in the format Name=endpoint_type,Values=endpoint_type1,endpoint_type2,....
        /// Name can be one of: db-cluster-endpoint-type, db-cluster-endpoint-custom-type,
        /// db-cluster-endpoint-id, db-cluster-endpoint-status. Values
        /// for the  db-cluster-endpoint-type filter can be one or more of: reader,
        /// writer, custom. Values for the db-cluster-endpoint-custom-type
        /// filter can be one or more of: reader, any. Values
        /// for the db-cluster-endpoint-status filter can be one or more of: available,
        /// creating, deleting, inactive, modifying.
        /// 
        /// 
        /// 
        public List Filters
        {
            get { return this._filters; }
            set { this._filters = value; }
        }
        // Check to see if Filters property is set
        internal bool IsSetFilters()
        {
            return this._filters != null && this._filters.Count > 0; 
        }
        /// 
        /// Gets and sets the property Marker. 
        /// 
        ///  An optional pagination token provided by a previous DescribeDBClusterEndpoints
        /// request. If this parameter is specified, the response includes only records beyond
        /// the marker, up to the value specified by MaxRecords. 
        /// 
        /// 
        public string Marker
        {
            get { return this._marker; }
            set { this._marker = value; }
        }
        // Check to see if Marker property is set
        internal bool IsSetMarker()
        {
            return this._marker != null;
        }
        /// 
        /// Gets and sets the property MaxRecords. 
        /// 
        /// The maximum number of records to include in the response. If more records exist than
        /// the specified MaxRecords value, a pagination token called a marker is
        /// included in the response so you can retrieve the remaining results. 
        /// 
        ///  
        /// 
        /// Default: 100
        /// 
        ///  
        /// 
        /// Constraints: Minimum 20, maximum 100.
        /// 
        /// 
        public int MaxRecords
        {
            get { return this._maxRecords.GetValueOrDefault(); }
            set { this._maxRecords = value; }
        }
        // Check to see if MaxRecords property is set
        internal bool IsSetMaxRecords()
        {
            return this._maxRecords.HasValue; 
        }
    }
}