/*
* Copyright 2010-2013 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.
*/
using System;
using System.Collections.Generic;
using System.Xml.Serialization;
using System.Text;
using System.IO;
using Amazon.Runtime;
using Amazon.Runtime.Internal;
namespace Amazon.S3.Model
{
///
/// Container for the parameters to the DeleteObjects operation.
/// This operation enables you to delete multiple objects from a bucket using a single HTTP request. You may specify up to 1000
/// keys.
///
public partial class DeleteObjectsRequest : AmazonWebServiceRequest
{
private string bucketName;
private bool? bypassGovernanceRetention;
private List objects = new List();
private bool? quiet;
private MfaCodes mfaCodes;
private RequestPayer requestPayer;
///
/// The bucket name containing the objects to delete.
/// When using this API with an access point, you must direct requests to the access point hostname.
/// The access point hostname takes the form AccessPointName-AccountId.s3-accesspoint.Region.amazonaws.com.
/// When using this operation using an access point through the AWS SDKs, you provide the access point
/// ARN in place of the bucket name. For more information about access point ARNs, see
/// Using Access Points
/// in the Amazon Simple Storage Service Developer Guide.
///
public string BucketName
{
get { return this.bucketName; }
set { this.bucketName = value; }
}
// Check to see if BucketName property is set
internal bool IsSetBucketName()
{
return this.bucketName != null;
}
///
/// Gets and sets the property BypassGovernanceRetention.
///
/// Specifies whether you want to delete this object even if it has a Governance-type
/// Object Lock in place. You must have sufficient permissions to perform this operation.
///
///
public bool BypassGovernanceRetention
{
get { return this.bypassGovernanceRetention.GetValueOrDefault(); }
set { this.bypassGovernanceRetention = value; }
}
// Check to see if BypassGovernanceRetention property is set
internal bool IsSetBypassGovernanceRetention()
{
return this.bypassGovernanceRetention.HasValue;
}
///
/// List of object keys to delete.
///
public List Objects
{
get
{
if (this.objects == null)
this.objects = new List();
return this.objects;
}
set { this.objects = value; }
}
// Check to see if Objects property is set
internal bool IsSetObjects()
{
return this.objects.Count > 0;
}
///
/// Toggles between Quiet and Verbose mode for the operation.
/// If set to true (Quiet mode), the response includes only those keys for objects on which
/// the delete operation failed.
///
///
/// By default this property is false and keys for both successful deletes
/// and failures are returned in the response.
///
public bool Quiet
{
get { return this.quiet ?? default(bool); }
set { this.quiet = value; }
}
// Check to see if Quiet property is set
internal bool IsSetQuiet()
{
return this.quiet.HasValue;
}
///
/// The MfaCodes Tuple associates the Serial Number and the current Token/Code displayed on the
/// Multi-Factor Authentication device associated with your AWS Account.
///
///
/// This is a required property for this request if:
/// 1. EnableMfaDelete was configured on the bucket
/// containing this object's version.
/// 2. You are deleting an object's version
///
public MfaCodes MfaCodes
{
get { return this.mfaCodes; }
set { this.mfaCodes = value; }
}
///
/// Checks if the MfaCodes property is set.
///
/// true if the MfaCodes property is set.
internal bool IsSetMfaCodes()
{
return (this.mfaCodes != null) &&
(!System.String.IsNullOrEmpty(MfaCodes.SerialNumber)) &&
(!System.String.IsNullOrEmpty(MfaCodes.AuthenticationValue));
}
///
/// Confirms that the requester knows that she or he will be charged for the list objects request.
/// Bucket owners need not specify this parameter in their requests.
///
public RequestPayer RequestPayer
{
get { return this.requestPayer; }
set { this.requestPayer = value; }
}
///
/// Checks to see if RequetsPayer is set.
///
/// true, if RequestPayer property is set.
internal bool IsSetRequestPayer()
{
return requestPayer != null;
}
}
}