/*
* 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 verifiedpermissions-2021-12-01.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.VerifiedPermissions.Model
{
///
/// The request failed because one or more input parameters don't satisfy their constraint
/// requirements. The output is provided as a list of fields and a reason for each field
/// that isn't valid.
///
///
///
/// The possible reasons include the following:
///
/// -
///
/// UnrecognizedEntityType
///
///
///
/// The policy includes an entity type that isn't found in the schema.
///
///
-
///
/// UnrecognizedActionId
///
///
///
/// The policy includes an action id that isn't found in the schema.
///
///
-
///
/// InvalidActionApplication
///
///
///
/// The policy includes an action that, according to the schema, doesn't support the specified
/// principal and resource.
///
///
-
///
/// UnexpectedType
///
///
///
/// The policy included an operand that isn't a valid type for the specified operation.
///
///
-
///
/// IncompatibleTypes
///
///
///
/// The types of elements included in a
set
, or the types of expressions
/// used in an if...then...else
clause aren't compatible in this context.
///
/// -
///
/// MissingAttribute
///
///
///
/// The policy attempts to access a record or entity attribute that isn't specified in
/// the schema. Test for the existence of the attribute first before attempting to access
/// its value. For more information, see the has
/// (presence of attribute test) operator in the Cedar Policy Language Guide.
///
///
-
///
/// UnsafeOptionalAttributeAccess
///
///
///
/// The policy attempts to access a record or entity attribute that is optional and isn't
/// guaranteed to be present. Test for the existence of the attribute first before attempting
/// to access its value. For more information, see the has
/// (presence of attribute test) operator in the Cedar Policy Language Guide.
///
///
-
///
/// ImpossiblePolicy
///
///
///
/// Cedar has determined that a policy condition always evaluates to false. If the policy
/// is always false, it can never apply to any query, and so it can never affect an authorization
/// decision.
///
///
-
///
/// WrongNumberArguments
///
///
///
/// The policy references an extension type with the wrong number of arguments.
///
///
-
///
/// FunctionArgumentValidationError
///
///
///
/// Cedar couldn't parse the argument passed to an extension type. For example, a string
/// that is to be parsed as an IPv4 address can contain only digits and the period character.
///
///
///
#if !NETSTANDARD
[Serializable]
#endif
public partial class ValidationException : AmazonVerifiedPermissionsException
{
private List _fieldList = new List();
///
/// Constructs a new ValidationException with the specified error
/// message.
///
///
/// Describes the error encountered.
///
public ValidationException(string message)
: base(message) {}
///
/// Construct instance of ValidationException
///
///
///
public ValidationException(string message, Exception innerException)
: base(message, innerException) {}
///
/// Construct instance of ValidationException
///
///
public ValidationException(Exception innerException)
: base(innerException) {}
///
/// Construct instance of ValidationException
///
///
///
///
///
///
///
public ValidationException(string message, Exception innerException, Amazon.Runtime.ErrorType errorType, string errorCode, string requestId, HttpStatusCode statusCode)
: base(message, innerException, errorType, errorCode, requestId, statusCode) {}
///
/// Construct instance of ValidationException
///
///
///
///
///
///
public ValidationException(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 ValidationException 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 ValidationException(System.Runtime.Serialization.SerializationInfo info, System.Runtime.Serialization.StreamingContext context)
: base(info, context)
{
this.FieldList = (List)info.GetValue("FieldList", 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("FieldList", this.FieldList);
}
#endif
///
/// Gets and sets the property FieldList.
///
/// The list of fields that aren't valid.
///
///
public List FieldList
{
get { return this._fieldList; }
set { this._fieldList = value; }
}
// Check to see if FieldList property is set
internal bool IsSetFieldList()
{
return this._fieldList != null && this._fieldList.Count > 0;
}
}
}