/*
 * 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 dlm-2018-01-12.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.DLM.Model
{
    /// 
    /// Bad request. The request is missing required parameters or has invalid parameters.
    /// 
    #if !NETSTANDARD
    [Serializable]
    #endif
    public partial class InvalidRequestException : AmazonDLMException
    {
        private string _code;
        private List _mutuallyExclusiveParameters = new List();
        private List _requiredParameters = new List();
        /// 
        /// Constructs a new InvalidRequestException with the specified error
        /// message.
        /// 
        /// 
        /// Describes the error encountered.
        /// 
        public InvalidRequestException(string message) 
            : base(message) {}
        /// 
        /// Construct instance of InvalidRequestException
        /// 
        /// 
        /// 
        public InvalidRequestException(string message, Exception innerException) 
            : base(message, innerException) {}
        /// 
        /// Construct instance of InvalidRequestException
        /// 
        /// 
        public InvalidRequestException(Exception innerException) 
            : base(innerException) {}
        /// 
        /// Construct instance of InvalidRequestException
        /// 
        /// 
        /// 
        /// 
        /// 
        /// 
        /// 
        public InvalidRequestException(string message, Exception innerException, Amazon.Runtime.ErrorType errorType, string errorCode, string requestId, HttpStatusCode statusCode) 
            : base(message, innerException, errorType, errorCode, requestId, statusCode) {}
        /// 
        /// Construct instance of InvalidRequestException
        /// 
        /// 
        /// 
        /// 
        /// 
        /// 
        public InvalidRequestException(string message, Amazon.Runtime.ErrorType errorType, string errorCode, string requestId, HttpStatusCode statusCode) 
            : base(message, errorType, errorCode, requestId, statusCode) {}
#if !NETSTANDARD
        /// 
        /// Constructs a new instance of the InvalidRequestException class with serialized data.
        /// 
        /// The  that holds the serialized object data about the exception being thrown.
        /// The  that contains contextual information about the source or destination.
        /// The  parameter is null. 
        /// The class name is null or  is zero (0). 
        protected InvalidRequestException(System.Runtime.Serialization.SerializationInfo info, System.Runtime.Serialization.StreamingContext context)
            : base(info, context)
        {
            this.Code = (string)info.GetValue("Code", typeof(string));
            this.MutuallyExclusiveParameters = (List)info.GetValue("MutuallyExclusiveParameters", typeof(List));
            this.RequiredParameters = (List)info.GetValue("RequiredParameters", typeof(List));
        }
        /// 
        /// Sets the  with information about the exception.
        /// 
        /// The  that holds the serialized object data about the exception being thrown.
        /// The  that contains contextual information about the source or destination.
        /// The  parameter is a null reference (Nothing in Visual Basic). 
#if BCL35
        [System.Security.Permissions.SecurityPermission(
            System.Security.Permissions.SecurityAction.LinkDemand,
            Flags = System.Security.Permissions.SecurityPermissionFlag.SerializationFormatter)]
#endif
        [System.Security.SecurityCritical]
        // These FxCop rules are giving false-positives for this method
        [System.Diagnostics.CodeAnalysis.SuppressMessage("Microsoft.Security", "CA2123:OverrideLinkDemandsShouldBeIdenticalToBase")]
        [System.Diagnostics.CodeAnalysis.SuppressMessage("Microsoft.Security", "CA2134:MethodsMustOverrideWithConsistentTransparencyFxCopRule")]
        public override void GetObjectData(System.Runtime.Serialization.SerializationInfo info, System.Runtime.Serialization.StreamingContext context)
        {
            base.GetObjectData(info, context);
            info.AddValue("Code", this.Code);
            info.AddValue("MutuallyExclusiveParameters", this.MutuallyExclusiveParameters);
            info.AddValue("RequiredParameters", this.RequiredParameters);
        }
#endif
        /// 
        /// Gets and sets the property Code.
        /// 
        public string Code
        {
            get { return this._code; }
            set { this._code = value; }
        }
        // Check to see if Code property is set
        internal bool IsSetCode()
        {
            return this._code != null;
        }
        /// 
        /// Gets and sets the property MutuallyExclusiveParameters. 
        /// 
        /// The request included parameters that cannot be provided together.
        /// 
        /// 
        public List MutuallyExclusiveParameters
        {
            get { return this._mutuallyExclusiveParameters; }
            set { this._mutuallyExclusiveParameters = value; }
        }
        // Check to see if MutuallyExclusiveParameters property is set
        internal bool IsSetMutuallyExclusiveParameters()
        {
            return this._mutuallyExclusiveParameters != null && this._mutuallyExclusiveParameters.Count > 0; 
        }
        /// 
        /// Gets and sets the property RequiredParameters. 
        /// 
        /// The request omitted one or more required parameters.
        /// 
        /// 
        public List RequiredParameters
        {
            get { return this._requiredParameters; }
            set { this._requiredParameters = value; }
        }
        // Check to see if RequiredParameters property is set
        internal bool IsSetRequiredParameters()
        {
            return this._requiredParameters != null && this._requiredParameters.Count > 0; 
        }
    }
}